app引导页
来源:互联网 发布:aspen plus软件参数 编辑:程序博客网 时间:2024/06/06 01:39
1、延时启动检测
这点没啥好说的,直接一个定时器即可,至于是否为第一次启动,则用sharedpreference来检测:
Timer timer = new Timer(); timer.schedule(new TimerTask() { @Override public void run() { SharedPreferences preferences = getSharedPreferences("guide",MODE_PRIVATE); boolean isfirst = preferences.getBoolean("isfirst",false); if (!isfirst) { startActivity(new Intent(SplseActivity.this, GuideActivity.class)); SharedPreferences.Editor editor = getSharedPreferences("guide",MODE_PRIVATE).edit(); editor.putBoolean("isfirst",true); editor.commit(); finish(); }else{ startActivity(new Intent(SplseActivity.this,MainActivity.class)); finish(); } } },2000);
2、圆点的绘制
上面圆点的绘制,其实很简单,我们的思路就是viewpager滑动到哪一个界面,就让它绘制成红色就可以了,所以,我们完全可以用shade属性和selector属性帮我们绘制完成。圆点如下:
<?xml version="1.0" encoding="utf-8"?><shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="oval"> <solid android:color="@color/colorAccent"/> <size android:height="10dp" android:width="10dp"/></shape>
然后,我们只要新建多一个,把颜色改成白色,然后用 selector 就可以改变不同的颜色了:
<?xml version="1.0" encoding="utf-8"?><selector xmlns:android="http://schemas.android.com/apk/res/android"> <item android:drawable="@drawable/point_select" android:state_selected="true"/> <item android:drawable="@drawable/point_normal" android:state_selected="false"/></selector>
至于多少个圆点,我们用动态的方式,即图片有多少张,这里就有多少个点;我们就可以使用setlayoutparmas的方式,设置我们的视图了。
首先看开机引导的主视图:
<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/activity_main" android:layout_width="match_parent" android:layout_height="match_parent" android:background="#2233" tools:context="com.rachel.guildproject.MainActivity"> <android.support.v4.view.ViewPager android:id="@+id/guide_viewpager" android:layout_width="match_parent" android:layout_height="match_parent"/> <Button android:id="@+id/guide_start" android:layout_width="200dp" android:layout_height="50dp" android:layout_alignParentBottom="true" android:layout_centerHorizontal="true" android:background="@drawable/btn_background" android:text="开始体验" android:textColor="#ffffff" android:textSize="20sp" android:textStyle="bold" android:layout_marginBottom="20dp" android:visibility="gone"/> <LinearLayout android:id="@+id/point_ly" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentBottom="true" android:layout_centerHorizontal="true" android:layout_marginBottom="40dp" android:orientation="horizontal"/></RelativeLayout>
viewpager 就不用讲了,button 则是我们最后一页的按钮,而 LinearLayout 则是我们的圆点绘制的,可以看到这里我把它设置成底部,这样,我们就可以在代码中去填充这些圆点了
private void initpoint() { //获取layout mLayout = (LinearLayout) findViewById(R.id.point_ly); LinearLayout.LayoutParams params = new LinearLayout.LayoutParams( LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT); //设置每一个view即圆点的对左的偏移量 params.setMargins(15,0,0,0); //根据图片多少来确定个数 for (int i = 0; i < imgRes.length; i++) { ImageView imageView = new ImageView(this); imageView.setImageResource(R.drawable.dot_select); imageView.setLayoutParams(params); //把上面的控件属性设置到LinearLayout中 if (i == 0){ //默认第一张为红色圆点 imageView.setSelected(true); }else{ imageView.setSelected(false); } //把圆点这个子视图导入我们的LinearLayout里面 mLayout.addView(imageView); mImageViews.add(imageView);//跟着viewpager变换颜色 } }
哪,是不是很简单啊,然后我们只要把viewpager填充进去就可以了,viewpager就老生常谈了,我这里就不讲了,我们只要在页面滑动完成之后,改变圆点的颜色就可以了,如下所示:
@Override public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) { //滑动时改变圆点的状态 for (int i = 0; i < mImageViews.size(); i++) { if (i == position){ mImageViews.get(i).setSelected(true); }else{ mImageViews.get(i).setSelected(false); } } //当为最后一个时,显示button,并隐藏圆点 if (position == mImageViews.size() -1){ mLayout.setVisibility(View.GONE); mButton.setVisibility(View.VISIBLE); ObjectAnimator animator = ObjectAnimator.ofFloat(mButton,"alpha",0f,1f); animator.setDuration(1000); animator.start(); }else{ mLayout.setVisibility(View.VISIBLE); mButton.setVisibility(View.GONE); } }
demo下载http://download.csdn.net/detail/qq_35549248/9919836
阅读全文
1 0
- app引导页
- app引导页
- app引导页
- APP引导页Demo
- Android App引导页
- app引导页
- APP引导页动画
- Android APP引导页制作
- app如何添加引导页。
- APP引导页的实现
- ViewPager+app新手引导页
- APP引导页滑动实现
- APP引导页的集成
- iOS App 引导页开发
- postDelay 实现app引导页
- App用户引导页如何引人入胜
- APP启动引导页实现方式
- 如何做好app的引导页
- C++学习(六)入门篇——确定常量类型
- 广播接受者 时间很短,不要用耗时的,不要超过16s。 这个运行在主线程。
- HDU 1856 More is better 基础并查集★(经典)
- 程序员面试笔记-数据库2
- 如何成为架构师系列:技术选型1
- app引导页
- 高清摄像头MIPI接口与ARM处理器的连接
- C++ algorithm sort自定义排序
- FFmpeg 编译
- 1039. 到底买不买
- 源码分析 There is no getter for property named '*' in 'class java.lang.String
- 二进制相加
- 初入webpack坑,从入门到放弃
- Fiddler 4 模拟 服务端返回 json