软件启动旋转动画:

布局:

  1. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  2. xmlns:tools="http://schemas.android.com/tools"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. android:id="@+id/rl_root"
  6. android:background="@drawable/splash_bg_newyear" >
  7.  
  8. <ImageView
  9. android:layout_width="wrap_content"
  10. android:layout_height="wrap_content"
  11. android:src="@drawable/splash_horse_newyear"
  12. />
  13.  
  14. </RelativeLayout>

Activity:

  1. package com.itheima.zhbj52;
  2. import android.app.Activity;
  3. import android.content.Intent;
  4. import android.os.Bundle;
  5. import android.view.animation.AlphaAnimation;
  6. import android.view.animation.Animation;
  7. import android.view.animation.Animation.AnimationListener;
  8. import android.view.animation.AnimationSet;
  9. import android.view.animation.RotateAnimation;
  10. import android.view.animation.ScaleAnimation;
  11. import android.widget.RelativeLayout;
  12.  
  13. import com.itheima.zhbj52.utils.PrefUtils;
  14. /**
  15. * 旋转首屏页
  16. */
  17. public class SplashActivity extends Activity {
  18. RelativeLayout rlRoot;
  19. @Override
  20. protected void onCreate(Bundle savedInstanceState) {
  21. super.onCreate(savedInstanceState);
  22. setContentView(R.layout.activity_splash);
  23. rlRoot = (RelativeLayout) findViewById(R.id.rl_root);//rl_root下面是一个ImageView是一张图片。
  24. startAnim();
  25. //LibUtils.doSomething();
  26. //rlRoot.setBackgroundResource(R.drawable.newscenter_press);
  27. }
  28.  
  29. /**
  30. * 开启动画
  31. */
  32. private void startAnim() {
  33. // 动画集合
  34. AnimationSet set = new AnimationSet(false);
  35. // 旋转动画
  36. RotateAnimation rotate = new RotateAnimation(0, 360,
  37. Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF,
  38. 0.5f);//RELATIVE_TO_SELF表示自身旋转,0.5f表示自身中心。
  39. rotate.setDuration(1000);// 动画时间
  40. rotate.setFillAfter(true);// 保持动画最后的状态
  41. // 缩放动画
  42. ScaleAnimation scale = new ScaleAnimation(0, 1, 0, 1,//宽和高从0到1,
  43. Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF,
  44. 0.5f);
  45. scale.setDuration(1000);// 动画时间
  46. scale.setFillAfter(true);// 保持动画状态
  47. // 渐变动画
  48. AlphaAnimation alpha = new AlphaAnimation(0, 1);
  49. alpha.setDuration(2000);// 动画时间
  50. alpha.setFillAfter(true);// 保持动画状态
  51.  
  52. set.addAnimation(rotate);
  53. set.addAnimation(scale);
  54. set.addAnimation(alpha);
  55. // 设置动画监听
  56. set.setAnimationListener(new AnimationListener() {
  57. @Override
  58. public void onAnimationStart(Animation animation) {
  59. }
  60. @Override
  61. public void onAnimationRepeat(Animation animation) {//动画重复的时候调用,
  62. }
  63. // 动画执行结束
  64. @Override
  65. public void onAnimationEnd(Animation animation) {
  66. jumpNextPage();
  67. }
  68. });
  69. rlRoot.startAnimation(set);
  70. }
  71.  
  72. /**
  73. * 跳转下一个页面
  74. */
  75. private void jumpNextPage() {
  76. // 判断之前有没有显示过新手引导
  77. boolean userGuide = PrefUtils.getBoolean(this, "is_user_guide_showed",
  78. false);
  79. if (!userGuide) {
  80. // 跳转到新手引导页
  81. startActivity(new Intent(SplashActivity.this, GuideActivity.class));
  82. } else {
  83. startActivity(new Intent(SplashActivity.this, MainActivity.class));
  84. }
  85. finish();//跳转到新页面后把当前页面结束
  86. }
  87. }

引导页面:

布局:

  1. <?xml version="1.0" encoding="utf-8"?>
  2.  
  3. <!-- 整体是一个相对布局,这样才会让控件叠加到另一个控件上 -->
  4. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  5. android:layout_width="match_parent"
  6. android:layout_height="match_parent" >
  7.  
  8. <!-- 第三方包 -->
  9. <android.support.v4.view.ViewPager
  10. android:id="@+id/vp_guide"
  11. android:layout_width="match_parent"
  12. android:layout_height="match_parent" />
  13.  
  14. <Button
  15. android:id="@+id/btn_start"
  16. android:layout_width="wrap_content"
  17. android:layout_height="wrap_content"
  18. android:layout_alignParentBottom="true"
  19. android:layout_centerHorizontal="true"
  20. android:layout_marginBottom="60dp"
  21. android:background="@drawable/btn_guide_selector" 按钮背景图片选择器
  22. android:padding="5dp"
  23. android:text="开始体验"
  24. android:visibility="invisible"
  25. android:textColor="@drawable/btn_guide_text_selector" /> 按钮文字选择器
  26.  
  27. <RelativeLayout
  28. android:layout_width="wrap_content"
  29. android:layout_height="wrap_content"
  30. android:layout_alignParentBottom="true"
  31. android:layout_centerHorizontal="true"
  32. android:layout_marginBottom="20dp" >
  33.  
  34. <!-- 3个黑色的圆点 -->
  35. <LinearLayout
  36. android:id="@+id/ll_point_group"
  37. android:layout_width="wrap_content"
  38. android:layout_height="wrap_content"
  39. android:orientation="horizontal" >
  40. </LinearLayout>
  41. <!-- 1个可以移动的红色圆点,默认压住第一个黑色圆点 -->
  42. <View
  43. android:id="@+id/view_red_point"
  44. android:layout_width="10dp"
  45. android:layout_height="10dp"
  46. android:background="@drawable/shape_point_red" />
  47. </RelativeLayout>
  48.  
  49. </RelativeLayout>

Activity:

  1. package com.itheima.zhbj52;
  2.  
  3. import java.util.ArrayList;
  4.  
  5. import android.app.Activity;
  6. import android.content.Intent;
  7. import android.os.Bundle;
  8. import android.support.v4.view.PagerAdapter;
  9. import android.support.v4.view.ViewPager;
  10. import android.support.v4.view.ViewPager.OnPageChangeListener;
  11. import android.view.View;
  12. import android.view.View.OnClickListener;
  13. import android.view.ViewGroup;
  14. import android.view.ViewTreeObserver.OnGlobalLayoutListener;
  15. import android.view.Window;
  16. import android.widget.Button;
  17. import android.widget.ImageView;
  18. import android.widget.LinearLayout;
  19. import android.widget.RelativeLayout;
  20.  
  21. import com.itheima.zhbj52.utils.PrefUtils;
  22.  
  23. /**
  24. * 新手引导
  25. */
  26. public class GuideActivity extends Activity {
  27.  
  28. private static final int[] mImageIds = new int[] { R.drawable.guide_1,
  29. R.drawable.guide_2, R.drawable.guide_3 };//三张图片
  30. private ViewPager vpGuide;
  31. private ArrayList<ImageView> mImageViewList;
  32. private LinearLayout llPointGroup;// 引导圆点的父控件
  33. private int mPointWidth;// 圆点间的距离
  34. private View viewRedPoint;// 小红点
  35. private Button btnStart;// 开始体验
  36.  
  37. @Override
  38. protected void onCreate(Bundle savedInstanceState) {
  39. super.onCreate(savedInstanceState);
  40. requestWindowFeature(Window.FEATURE_NO_TITLE);// 去掉标题,在setContentView方法之前调用。
  41. setContentView(R.layout.activity_guide);
  42. vpGuide = (ViewPager) findViewById(R.id.vp_guide);
  43. llPointGroup = (LinearLayout) findViewById(R.id.ll_point_group);//3个黑色的圆点
  44. viewRedPoint = findViewById(R.id.view_red_point);
  45. btnStart = (Button) findViewById(R.id.btn_start);//开始体验按钮
  46. btnStart.setOnClickListener(new OnClickListener() {
  47. @Override
  48. public void onClick(View v) {
  49. // 更新sp, 表示已经展示了新手引导
  50. PrefUtils.setBoolean(GuideActivity.this,
  51. "is_user_guide_showed", true);
  52. // 跳转主页面
  53. startActivity(new Intent(GuideActivity.this, MainActivity.class));
  54. finish();//当前页面消失
  55. }
  56. });
  57. initViews();
  58. vpGuide.setAdapter(new GuideAdapter());//ViewPager要设置Adapter
  59. vpGuide.setOnPageChangeListener(new GuidePageListener());//ViewPager滑动时的监听器
  60. }
  61.  
  62. /**
  63. * 初始化界面
  64. */
  65. private void initViews() {
  66. mImageViewList = new ArrayList<ImageView>();
  67.  
  68. // 初始化引导页的3个页面
  69. for (int i = 0; i < mImageIds.length; i++) {
  70. ImageView image = new ImageView(this);
  71. image.setBackgroundResource(mImageIds[i]);// 设置引导页背景
  72. mImageViewList.add(image);
  73. }
  74.  
  75. // 动态初始化小圆点,便于代码的扩展。
  76. for (int i = 0; i < mImageIds.length; i++) {
  77. View point = new View(this);
  78. point.setBackgroundResource(R.drawable.shape_point_gray);// 所有的View都有背景,
  79. LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(
  80. 10, 10);//宽高为10像素,因为圆点的父控件是LinearLayout所以这里用LinearLayout.LayoutParams,
  81. if (i > 0) {
  82. params.leftMargin = 10;// 设置圆点间隔
  83. }
  84. point.setLayoutParams(params);// 设置圆点的大小
  85. llPointGroup.addView(point);// 将圆点动态添加给线性布局
  86. }
  87. //控件出现的时候会经过measure()方法测量控件的宽高,layout()方法用来决定将控件放在哪个地方,ondraw()方法来画控件。
  88. // 获取视图树(因为整个页面的布局是一层一层的xml节点树), 对layout方法结束的事件进行监听
  89. llPointGroup.getViewTreeObserver().addOnGlobalLayoutListener(
  90. new OnGlobalLayoutListener() {
  91. // 当layout方法执行结束后回调此方法
  92. @Override
  93. public void onGlobalLayout() {
  94. System.out.println("layout 结束");
  95. llPointGroup.getViewTreeObserver()
  96. .removeGlobalOnLayoutListener(this);//以后不再监听,this是OnGlobalLayoutListener对象,这是一个内部类。
  97. mPointWidth = llPointGroup.getChildAt(1).getLeft()
  98. - llPointGroup.getChildAt(0).getLeft();//getLeft()是返回圆点的左边到页面左边的距离,getRight()是返回圆点的右边到页面左边的距离。
  99. System.out.println("圆点距离:" + mPointWidth);//
  100. }
  101. });
  102. }
  103.  
  104. /**
  105. * ViewPager数据适配器
  106. */
  107. class GuideAdapter extends PagerAdapter {
  108. @Override
  109. public int getCount() {
  110. return mImageIds.length;
  111. }
  112. @Override
  113. public boolean isViewFromObject(View arg0, Object arg1) {
  114. return arg0 == arg1;
  115. }
  116. @Override
  117. public Object instantiateItem(ViewGroup container, int position) {//类似于listView的getView()方法,
  118. container.addView(mImageViewList.get(position));//mImageViewList.get(position)返回的是ImageView,
  119. return mImageViewList.get(position);
  120. }
  121. @Override
  122. public void destroyItem(ViewGroup container, int position, Object object) {
  123. container.removeView((View) object);//删除一个
  124. }
  125. }
  126.  
  127. /**
  128. * viewpager的滑动监听
  129. */
  130. class GuidePageListener implements OnPageChangeListener {
  131. // 滑动事件,滑动的过程中这个方法一直调用。
  132. @Override
  133. public void onPageScrolled(int position, float positionOffset,
  134. int positionOffsetPixels) {
  135. //position是当前页面的位置,positionOffset偏移百分比,positionOffsetPixels是偏移的像素,
  136. //从一个页面滑到第二个页面的时候positionOffset从0到100%并且到第二个页面的时候百分比又变为0,positionOffsetPixels从0到页面的宽度到达第二个页面的时候偏移量又淸0。
  137. System.out.println("当前位置:" + position + ";百分比:" + positionOffset
  138. + ";移动距离:" + positionOffsetPixels);
  139. int len = (int) (mPointWidth * positionOffset) + position
  140. * mPointWidth;//mPointWidth * positionOffset是圆点的距离乘以移动的百分比,
  141. RelativeLayout.LayoutParams params = (RelativeLayout.LayoutParams) viewRedPoint
  142. .getLayoutParams();// 获取当前红点的布局参数,因为红色的点是在UI文件写的所以已经有了LayoutParams,而黑色的点是动态生成的没有LayoutParams,红色点的父节点是相对布局,
  143. params.leftMargin = len;// 设置左边距
  144. viewRedPoint.setLayoutParams(params);// 重新给小红点设置布局参数
  145. }
  146.  
  147. // 某个页面被选中
  148. @Override
  149. public void onPageSelected(int position) {
  150. if (position == mImageIds.length - 1) {// 最后一个页面
  151. btnStart.setVisibility(View.VISIBLE);// 显示开始体验的按钮
  152. } else {
  153. btnStart.setVisibility(View.INVISIBLE);
  154. }
  155. }
  156.  
  157. // 滑动状态发生变化(正在滑动 滑动松开状态,)
  158. @Override
  159. public void onPageScrollStateChanged(int state) {
  160.  
  161. }
  162.  
  163. }
  164.  
  165. }
  1. <!-- 图片颜色选择器(drawable文件夹里面) -->
  2.  
  3. <?xml version="1.0" encoding="utf-8"?>
  4. <selector xmlns:android="http://schemas.android.com/apk/res/android">
  5.  
  6. <item android:drawable="@drawable/button_red_pressed" android:state_pressed="true"/> <!-- 被点击之后 -->
  7. <item android:drawable="@drawable/button_red_normal"/>
  8.  
  9. </selector>
  1. <!-- 文字颜色选择器(drawable文件夹里面) -->
  2. <?xml version="1.0" encoding="utf-8"?>
  3. <selector xmlns:android="http://schemas.android.com/apk/res/android">
  4.  
  5. <item android:state_pressed="true" android:color="@android:color/black"/> <!-- 文字点击后是黑色 -->
  6. <item android:color="@android:color/white"/> <!-- 文字默认是白色 -->
  7.  
  8. </selector>
  1. <!-- 不可以移动的黑色的圆点 -->
  2. <?xml version="1.0" encoding="utf-8"?>
  3. <shape xmlns:android="http://schemas.android.com/apk/res/android"
  4. android:shape="oval" > <!-- shape下面的oval是圆形 -->
  5.  
  6. <solid android:color="@android:color/darker_gray" /> <!-- 圆形是灰色 -->
  7.  
  8. </shape>
  1. <!-- 红色可以移动的圆点 -->
  2. <?xml version="1.0" encoding="utf-8"?>
  3. <shape xmlns:android="http://schemas.android.com/apk/res/android"
  4. android:shape="oval" >
  5.  
  6. <solid android:color="#f00" /> <!-- 圆点颜色是红色 -->
  7.  
  8. </shape>
  1. package com.itheima.zhbj52.utils;
  2.  
  3. import android.content.Context;
  4. import android.content.SharedPreferences;
  5.  
  6. /**
  7. * SharePreference封装
  8. *
  9. * @author Kevin
  10. *
  11. */
  12. public class PrefUtils {
  13.  
  14. public static final String PREF_NAME = "config";
  15.  
  16. public static boolean getBoolean(Context ctx, String key,
  17. boolean defaultValue) {
  18. SharedPreferences sp = ctx.getSharedPreferences(PREF_NAME,
  19. Context.MODE_PRIVATE);
  20. return sp.getBoolean(key, defaultValue);
  21. }
  22.  
  23. public static void setBoolean(Context ctx, String key, boolean value) {
  24. SharedPreferences sp = ctx.getSharedPreferences(PREF_NAME,
  25. Context.MODE_PRIVATE);
  26. sp.edit().putBoolean(key, value).commit();
  27. }
  28. }

清单文件:

<activity android:name=".GuideActivity" />
<activity android:name=".MainActivity" />

android120 zhihuibeijing 开机页面的更多相关文章

  1. 【技术】关于安卓使用禁用服务(或者是MYANDROIDTOOLS里面的禁用服务)后卡在开机页面的(或者是卡在各种页面的)

    目前会出现禁用部分服务后卡在开机页面,导致到手机数据得全部清除在网上找了很久,都没找到还原的方法只好自己开垦新方案了推测:由于格式化DATA分区后,手机可以正常开机,所以认为禁用服务的配置内容保存在D ...

  2. 老司机学新平台 - Xamarin Forms开发框架二探 (Prism vs MvvmCross)

    在上一篇Xamarin开发环境及开发框架初探中,曾简单提到MvvmCross这个Xamarin下的开发框架.最近又评估了一些别的,发现老牌Mvvm框架Prism现在也支持Xamarin Forms了, ...

  3. Win7与Mint双系统安装体验

    双系统安装前的准备 1.安装前的准备 安装双系统可能会对磁盘文件带来一些影响,为了避免在安装过程中由于系统瘫痪造成不必要的损失,所以我们在准备安装双系统之前,要对PC机中的重要文件进行备份,对资料要做 ...

  4. Linux的安全模式

    今天尝试了一下开机启动,在rc.local中进行设置,但是我写的java -jar transport.jar是一个Hold处理,无法退出:导致开机的时候一直停留在等待页面. 处理机制: 1. 在Li ...

  5. Prism vs MvvmCross

    Prism vs MvvmCross 在上一篇Xamarin开发环境及开发框架初探中,曾简单提到MvvmCross这个Xamarin下的开发框架.最近又评估了一些别的,发现老牌Mvvm框架Prism现 ...

  6. 最小化安装linux CentOS_7操作系统

    实验环境为VMware虚拟机安装操作系统. 1.打开VMware Workstation 虚拟机,选择创建新的虚拟机: 2.选择linux-CentOS 64位操作系统: 3.为虚拟机命名,并选择安装 ...

  7. Dell台式机Window10恢复重装window7步骤

    1.开机页面出现Dell标识时,连续点击F2 2.进入bois页面,选择boot ,将光标移动到USB启动盘符位置, 3.按 - 号,将 USB Srorage Device 改为第一启动项,F10保 ...

  8. win10切换AHCI模式

    win10切换AHCI模式 笔记本电脑总是卡卡的,开机好慢,一狠心就买了一个固态硬盘装上.听说电脑开启AHCI模式跟固态硬盘更配哦.所以好好得鼓捣了一下电脑. 保证win10开启了安全模式, 如果没有 ...

  9. 20165315 预备作业3 Linux安装及学习

    20165315 预备作业3 Linux安装及学习 一.在自己笔记本上安装Linux操作系统 因为对操作电脑的不熟悉,我在第一项任务上就花费了一定的时间,在安装过程有如下问题: 我的电脑是苹果公司的M ...

随机推荐

  1. vijos 1563 疯狂的方格取数

    P1653疯狂的方格取数 Accepted 标签:天才的talent[显示标签]   背景 Due to the talent of talent123,当talent123做完NOIP考了两次的二取 ...

  2. [POJ 2461] Billiard

    同swustoj 11 Billiard Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 1362   Accepted: 8 ...

  3. [LOJ 1030] Discovering Gold

    B - Discovering Gold Time Limit:2000MS     Memory Limit:32768KB     64bit IO Format:%lld & %llu ...

  4. nopcommerce商城系统--源代码结构和架构

    这个文档是让开发者了解nopcommerce解决方案结构的指南.这是新的nopcommerce开发者学习nopcommerce代码的相关文档.首先,nopCommerce源代码是很容易得到的.它是一个 ...

  5. 常用ping服务列表

    以下是收集的ping服务器. ping是基于XML_RPC标准协议的更新通告服务,是用于blog在内容更新时通知博客搜索引擎及时进行抓取.更新的方式.博客搜索引擎在成功接受到ping以后,会立刻进行抓 ...

  6. 从代码都发布遇到的问题总结(C#调用非托管dll文件,部署项目) 转

    http://www.cnblogs.com/Purple_Xiapei/archive/2012/06/30/2570928.html

  7. 恒天云技术分享系列2 - vlan管理GUI开发

    恒天云:http://www.hengtianyun.com/download-show-id-10.html 在OpenStack G版本中quantum网络模式下,horizon提供了基于quan ...

  8. HDU-4618 Palindrome Sub-Array 暴力枚举

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4618 直接暴力枚举中心点,在中间如果求不出最大值直接跳过优化下... //STATUS:C++_AC_ ...

  9. HDU-4612 Warm up 边双连通分量+缩点+最长链

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4612 简单图论题,先求图的边双连通分量,注意,此题有重边(admin还逗比的说没有重边),在用targ ...

  10. ant -verbose -debug ...

    ant -verbose -debug  (target) 可以让ant打印出所执行的command任务