使用ViewPager模拟实现应用程序启动界面
经常在开发应用程序的时候,软件启动有启用动画界面,一般使用图片来进行界面该版本最新更新等等内容,今天来使用ViewPager来模拟实现这功能,也希望对大家有个小小的参考作用,在以后的项目中能够使用到。
首先准备工作,若干张需要进行显示的图片和底部用到的小圆圈
项目结构图如下:
2:运行效果图
大致效果如上,具体编码实现:
布局文件是android.support.v4.view.ViewPager和底部五个小圆圈main.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
> <android.support.v4.view.ViewPager
android:id="@+id/myViewpager"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
/> <LinearLayout
android:id="@+id/linearlayout"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:layout_alignParentBottom="true"
android:layout_centerHorizontal="true"
>
<ImageView
android:id="@+id/img1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/point_selector"
android:padding="17dip"/>
<ImageView
android:id="@+id/img2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/point_selector"
android:padding="17dip"/>
<ImageView
android:id="@+id/img3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/point_selector"
android:padding="17dip"/>
<ImageView
android:id="@+id/img4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/point_selector"
android:padding="17dip"/>
<ImageView
android:id="@+id/img5"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/point_selector"
android:padding="17dip"/> </LinearLayout> </RelativeLayout>
ViewPageAdapter.java ViewPager页面的适配器
/**
* 自定义ViewPager适配器
* @author jiangqingqing
*
*/
public class MyViewPagerAdapter extends PagerAdapter { private List<View> mLists;
public MyViewPagerAdapter(List<View> pLists)
{
this.mLists=pLists;
}
@Override
public int getCount() {
// TODO Auto-generated method stub
return mLists.size();
} @Override
public boolean isViewFromObject(View arg0, Object arg1) {
// TODO Auto-generated method stub
return arg0==arg1;
} @Override
public void destroyItem(View container, int position, Object object) {
((ViewPager)container).removeView(mLists.get(position));
} @Override
public Object instantiateItem(View container, int position) {
((ViewPager)container).addView(mLists.get(position));
return mLists.get(position);
}
MainActicvity.java
/**
* 使用ViePager简单模拟 应用的启动动画界面
* @author jiangqingqing
*
*/
public class MainActivity extends Activity { private ViewPager mViewPager;
private MyViewPagerAdapter mAdapter;
private LinearLayout mLinearLayout;
private List<View> mLists = new ArrayList<View>();
private Integer[] img_ids = new Integer[] { R.drawable.guide_01,
R.drawable.guide_02, R.drawable.guide_03, R.drawable.guide_04,
R.drawable.guide_05 };
private ImageView[] points = new ImageView[img_ids.length]; private int current=0;//默认在第一页
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
mViewPager = (ViewPager) this.findViewById(R.id.myViewpager);
mLinearLayout = (LinearLayout) this.findViewById(R.id.linearlayout); //把需要显示的图片加入到ViewPager页面集合中
for (int i = 0; i < img_ids.length; i++) {
ImageView iv = new ImageView(this);
iv.setLayoutParams(new LinearLayout.LayoutParams(
LinearLayout.LayoutParams.FILL_PARENT,
LinearLayout.LayoutParams.FILL_PARENT));
iv.setImageResource(img_ids[i]);
mLists.add(iv);
} mAdapter=new MyViewPagerAdapter(mLists);
mViewPager.setAdapter(mAdapter); //为ViewPager选项卡添加 切换时候的监听
mViewPager.setOnPageChangeListener(new MyOnPagerChangeListener());
//初始化下面的小圆点
initPoints();
} //初始化下面的小圆点
private void initPoints()
{
for(int i=0;i<img_ids.length;i++)
{
points[i]=(ImageView)mLinearLayout.getChildAt(i);
points[i].setImageResource(R.drawable.point_normal); }
current=0;//默认在第一页
points[current].setImageResource(R.drawable.point_select);//此刻处于第一页,把第一页的小圆圈设置为unenabled
} class MyOnPagerChangeListener implements OnPageChangeListener
{
@Override
public void onPageScrollStateChanged(int arg0) { }
@Override
public void onPageScrolled(int arg0, float arg1, int arg2) { }
@Override
public void onPageSelected(int arg0) { points[arg0].setImageResource(R.drawable.point_select);
points[current].setImageResource(R.drawable.point_normal);
current=arg0;
} }
这个Demo例子比较简单,但是可以实现我们需要的效果。详细代码在下面的链接,有兴趣的可以下载下来跑一下
http://download.csdn.net/detail/jiangqq781931404/5776739
使用ViewPager模拟实现应用程序启动界面的更多相关文章
- Qt系统对话框中文化及应用程序实现重启及使用QSS样式表文件及使用程序启动界面
一.应用程序中文化 1).Qt安装目录下有一个目录translations/,在此目录下有qt_zh_CN.ts和 qt_zh_CN.qm把它们拷贝到你的工程目录下. 2).在main函数加入下列代码 ...
- Android -- 使用主题配置文件,去掉程序启动界面的短暂黑屏
关于黑屏 默认的情况下,程序启动时,会有一个黑屏的时期,原因是,首个activity会加载一些数据,比如初始化列表数据等. 去除步骤 1./res/values/styles.xml 在 Theme ...
- QT程序启动界面的使用
当程序的初始化工作比较多,程序可能启动较长时间后,窗口才会显示出来,用户没准会抱怨程序响应的慢. 为了改善用户体验,最好在程序初始化这段时间显示logo,或者其他信息提示用户程序已启动.QT提供了QS ...
- 在AndroidManifest.xml文件中设置Android程序的启动界面方法
从网上搜集了一堆的Android代码,比如Android的Login程序和Android的Helloworld程序,但是却总不能正确运行一个正确的程序,郁闷了很久,终于在一次一次的测试后成功的在And ...
- 用ViewPager实现一个程序引导界面
下面使用ViewPager来实现一个程序引导的demo: 一般来说,引导界面是出现第一次运行时出现的,之后不会再出现.所以需要记录是否是第一次使用程序,办法有很多,最容易想到的就是使用SharedPr ...
- 在windowService用Process.Start()启动程序没有界面-记录
1.在服务程序安装时编程实现,ProjectInstaller.cs using System; using System.Collections; using System.Collection ...
- 应用程序启动后修改自身EXE文件或自删除EXE文件(附VC++6.0源码)
在CSDN论坛看到这么一个问题:如何为第三方工具加上使用限制次数?问题的答案很简单,重新做一个应用程序,将第三方程序打包进这个应用程序,启动应用程序时可以检查第三方工具的使用次数,检查通过,可运行第三 ...
- 【PyQt5-Qt Designer】制作炫酷的启动界面+进度条
QProgressBar 进度条+QSplashScreen 启动界面 知识点: 1.进度条 #将进度条的最大值.最小值设置为相同时,产生跑马灯效果 self.progressBar.setMinim ...
- 用C#实现模拟双色球中奖程序 控制台应用程序
前言 这是我在大一第一学期C#的课程设计,要求编写一个模拟双色球彩票的控制台应用程序,用以实现简单的模拟选购彩票. 一.双色球购号号码生成: 1.系统购号:通过"随机数"产生双色球 ...
随机推荐
- NOIP2014解题报告
day 1 1.生活大爆炸版石头剪刀布(rps) 直接按照题意模拟即可 #include<cstdio> #include<algorithm> #include<cst ...
- Lake Counting(poj 2386)
题目描述: Description Due to recent rains, water has pooled in various places in Farmer John's field, wh ...
- S2S:分享出的营销机遇
(速途网专栏 作者:高学争)经常在网上购物的你,有没有遇到过这样的问题:你知道自己想买什么,但是在淘宝上一搜,出来了数以万计的同类型,他们有着同样的价位(甚至可能是同样的图片),但是由不同的商家提供, ...
- Chrome Firefox 自定义背景色
Chrome有个自定义背景色的文件 Custom.css 默认里面什么字都没写 html, body {background-color: #e0dcc0!important;} 这个颜色 ...
- Week15(12月16日):授课综述1
Part I:提问 =========================== 1.( )类提供了一个对Entity Framework的抽象,能够进行数据持久化并接受数据. A.Layout ...
- WebRTC–getUserMedia & Canvas
下面是一个使用getUserMedia接口和Canvas的drawImage方法实现的截图功能(截取视频中的一帧). 基本思路是这样子的: getUserMedia获取一个MediaStream, s ...
- hibernate 持久化对象的生命周期 2.1
持久化对象的生命周期 瞬态(自由态) 表示对象在内存中存在,在数据库中没有数据相关,比如刚刚new出来的一个对象 持久态 持久态指的是持久化对象处于由Hibernate管理的状态,这种状态下持久化对象 ...
- Error Unable to start the Genymotion virtual device.解决
The Genymotion virtual device could not obtain an IP address.For an unknown reason.VirtualBox DHCP h ...
- cocos2dx进阶学习之CCLayer
继承关系 CCLayer -> CCNode,CCTouchDelegate,CCAccelerometerDelegate,CCKeypadDelegate CCLayer在cocos2dx中 ...
- 基于visual Studio2013解决C语言竞赛题之0204实数求值
题目