• 是男人就下100层【第一层】——高仿微信界面(1)


      从今天开始将进行一个特别有趣且有意义的专栏《是男人就下100层》,计划对市面上比较火的应用进行高度仿照,并将开发过程贴出来,和大家交流和分享。由于时间关系可能进度会比较缓慢,但是任何事情如果没有开始,只是头脑里的一个想法,可能会错过很多机会。在此先声明一点:由于个人能力有限,有什么不对的地方或者需要改进的地方请各位朋友能够指出。好吧,直接进入正题【第一层】的目标是高仿微信界面。

      先下载一个微信的apk文件,安装到手机启动后依次可以看到下图两个界面:

            

    接下来创建我们的工程(工程名:weixin)

    闪屏界面AppStart的布局文件

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:background="@drawable/welcome" >
    
    </LinearLayout>
    
    闪屏界面有很多种写法,可以在Activity中添加一个动画改变屏幕透明度,或者在主题中给Activity的启动添加进入退出动画效果。

    AppStart Activity的主题定义:

        <style name="AnimFade" parent="@android:style/Animation.Activity">  
        	<item name="android:activityOpenEnterAnimation">@anim/fade_in</item>  
        	<item name="android:activityOpenExitAnimation">@anim/hold</item>        
        	<item name="android:activityCloseEnterAnimation">@anim/fade_in</item>  
        	<item name="android:activityCloseExitAnimation">@anim/fade_out</item> 
        </style>
    
        <style name="Anim_style" parent="android:Theme.NoTitleBar">         
            <item name="android:windowAnimationStyle">@style/AnimFade</item>       
        </style> 
    该主题继承自Android系统主题Theme.NoTitleBar用自定义动画覆盖了windowAnimationStyle属性

    activityOpenEnterAnimation:表示activity创建效果

    activityOpenExitAnimation:表示还没有调用finish()的退出效果

    activityCloseEnterAnimation:表示返回上一个activity进入效果

    activityCloseEnterAnimation:表示activity调用finish()后退出效果

    anim/fade_in.xml

    <?xml version="1.0" encoding="utf-8"?>
    <alpha xmlns:android="http://schemas.android.com/apk/res/android"
        android:interpolator="@android:anim/accelerate_interpolator"
        android:fromAlpha="0.0" android:toAlpha="1.0"
        android:duration="300" />

    interpolator定义的是动画的变化率(alpha, scale, translate, rotate)能够加速、减速、重复等。

    上面定义的是加速动画,透明度从0到1,持续300毫秒

    anim/fade_out.xml

    <?xml version="1.0" encoding="utf-8"?>
    <alpha xmlns:android="http://schemas.android.com/apk/res/android"
        android:interpolator="@android:anim/accelerate_interpolator"
        android:fromAlpha="1.0" android:toAlpha="0.0"
        android:duration="300" />
    和上面的基本相似,只是透明度部分不同。

    anim/hold.xml

    <?xml version="1.0" encoding="utf-8"?> 
    <translate xmlns:android="http://schemas.android.com/apk/res/android"
           android:interpolator="@android:anim/accelerate_interpolator"
           android:fromXDelta="0" android:toXDelta="0"
           android:duration="300" />
    位移变化动画。

    在manifest中配置AppStart的主题

    <?xml version="1.0" encoding="utf-8"?>
    <manifest xmlns:android="http://schemas.android.com/apk/res/android"
        package="com.example.weixin"
        android:versionCode="1"
        android:versionName="1.0" >
    
        <uses-sdk
            android:minSdkVersion="8"
            android:targetSdkVersion="18" />
    
        <application
            android:allowBackup="true"
            android:icon="@drawable/ic_launcher"
            android:label="@string/app_name"
            android:theme="@style/AppTheme" >
            <activity
                android:name=".activity.AppStart"
                android:label="@string/app_name"
                android:theme="@style/Anim_style">
                <intent-filter>
                    <action android:name="android.intent.action.MAIN" />
    
                    <category android:name="android.intent.category.LAUNCHER" />
                </intent-filter>
            </activity>
            <activity
                android:name=".activity.Welcome">
                
            </activity>
        </application>
    
    </manifest>
    
    上面的代码已经实现了上面的第一个图的效果,下面我们来运行一下

    运行效果



    下一篇我们来实现上面第二个图的效果,有什么问题或建议请在下面留言或加入左边的交流群交流。

    下一篇:http://blog.csdn.net/dawanganban/article/details/20007513


  • 相关阅读:
    CSS: 三栏布局
    CSS: 实现两栏布局,左边固定,右边自适应的4种方法
    css清除浮动
    浏览器解析时间线
    @Valid解决无法校验List问题
    Docker+Jenkins+Git+Maven实现Springboot项目自动化部署
    Git安装(CentOS)
    Jenkins安装
    Docker安装(Centos)
    Maven安装(Linux)
  • 原文地址:https://www.cnblogs.com/lanzhi/p/6469180.html
Copyright © 2020-2023  润新知