<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity"> <androidx.viewpager.widget.ViewPager
android:id="@+id/first_viewpager"
android:layout_width="match_parent"
android:layout_height="match_parent" >
</androidx.viewpager.widget.ViewPager> <LinearLayout
android:id="@+id/viewpager_tag_viewgroup"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_marginBottom="32dp"
android:gravity="center_horizontal"
android:orientation="horizontal"
android:layout_marginRight="60px"
android:padding="20dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.0"
app:layout_constraintStart_toStartOf="parent"></LinearLayout> <Button
android:id="@+id/view_pager_button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_above="@id/viewpager_tag_viewgroup"
android:layout_centerHorizontal="true"
android:layout_marginBottom="128dp"
android:background="@drawable/shap3" android:text="立即体验"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.498"
app:layout_constraintStart_toStartOf="parent" /> </androidx.constraintlayout.widget.ConstraintLayout>
public class MainActivity extends Activity implements ViewPager.OnPageChangeListener {

        private ViewPager mViewPager;
//图片资源的数组
private int[] mImageIdArray;
//图片的集合
private List<View> mViewList;
//放置圆点
private ViewGroup mViewGroup;
//实例化圆点View
private ImageView mImageView;
private ImageView[] mImageViewArray;
//最后一页的按钮
private Button mButton; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState); requestWindowFeature(Window.FEATURE_NO_TITLE);
getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
WindowManager.LayoutParams.FLAG_FULLSCREEN); setContentView(R.layout.activity_main); mButton = (Button) findViewById(R.id.view_pager_button);
mButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// startActivity(new Intent(ViewPagerActivity.this, LoginActivity.class));
// finish();
}
});
//加载ViewPager
initViewpager();
//加载底部圆点
initViewPagerTag(); } /**
* 加载底部圆点
*/
private void initViewPagerTag() {
//这里实例化LinearLayout
mViewGroup = (ViewGroup) findViewById(R.id.viewpager_tag_viewgroup);
//根据ViewPager的item数量实例化数组
mImageViewArray = new ImageView[mViewList.size()];
//循环新建底部圆点imageview,将生成的imageview保存到数组中
for (int i = 0; i < mViewList.size(); i++) {
mImageView = new ImageView(this);
LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(20, 20);
layoutParams.leftMargin = 60;
mImageView.setLayoutParams(layoutParams); mImageViewArray[i] = mImageView;
//第一个页面需要设为选中状态,这里要使用两张不同的图片(选中与未选中)
if (i == 0) {
mImageView.setBackgroundResource(R.drawable.shap1);
} else {
mImageView.setBackgroundResource(R.drawable.shap2);
}
//将数组中的imageview加入到viewgroup
mViewGroup.addView(mImageViewArray[i]);
}
} /**
* 加载ViewPager
*/
private void initViewpager() {
mViewPager = (ViewPager) findViewById(R.id.first_viewpager);
//实例化图片资源
mImageIdArray = new int[]{R.drawable.lunch1, R.drawable.lunch2, R.drawable.lunch3, R.drawable.lunch4}; mViewList = new ArrayList<View>();
//获取一个layout参数,设置为match_parent
LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT
, LinearLayout.LayoutParams.MATCH_PARENT); //循环创建view并进入集合
for (int i = 0; i < mImageIdArray.length; i++) {
//new imageview并设置全屏和图片资源
ImageView imageView = new ImageView(this);
imageView.setLayoutParams(params);
imageView.setBackgroundResource(mImageIdArray[i]); //将imageview加入到View集合中
mViewList.add(imageView);
}
//View集合数据初始化好,setAdapter就可以了
mViewPager.setAdapter(new GuidePagerAdapter(mViewList));
//添加ViewPager的滑动监听,注意是.add...以前是setOnPageChangeListener方法,已过时
mViewPager.addOnPageChangeListener(this);
} @Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) { }
//滑动后的监听
@Override
public void onPageSelected(int position) {
//循环设置当前页的标记图
for (int i = 0; i < mImageViewArray.length; i++) {
mImageViewArray[position].setBackgroundResource(R.drawable.shap1);
if (position != i) {
mImageViewArray[i].setBackgroundResource(R.drawable.shap2);
}
}
//判断是否最后一页,是则显示button
if (position == mImageViewArray.length - 1) {
mButton.setVisibility(View.VISIBLE);
} else {
mButton.setVisibility(View.GONE);
}
} @Override
public void onPageScrollStateChanged(int state) { }
}
  public class GuidePagerAdapter extends PagerAdapter {
private List<View> viewList; public GuidePagerAdapter(List<View> viewList) {
this.viewList = viewList;
}
/**
* 返回页面的个数
*
* @return
*/
@Override
public int getCount() {
if (viewList != null) {
return viewList.size();
}
return 0;
} /**
* 判断是否由对象生成界面
*
* @param view
* @param object
* @return
*/
@Override
public boolean isViewFromObject(View view, Object object) {
return view == object;
} /**
* 初始化position位置的界面
*
* @param container
* @param position
* @return
*/
@Override
public Object instantiateItem(ViewGroup container, int position) {
((ViewPager) container).addView(viewList.get(position), 0);
return viewList.get(position);
} /**
* 移除页面
*
* @param container
* @param position
* @param object
*/
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
((ViewPager) container).removeView(viewList.get(position));
}
}
<shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="oval" >

    <corners android:radius="5dp" />
<solid android:color="@android:color/white" /> </shape>
<shape xmlns:android="http://schemas.android.com/apk/res/android"  android:shape="oval" >

    <corners android:radius="5dp" />
<solid android:color="@android:color/darker_gray" /> </shape>
<shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle">
<corners android:radius="10dp" />
<solid android:color="@android:color/holo_blue_bright" /> </shape>

viewpage启动页的更多相关文章

  1. ionic 图标以及启动页图片不能正确加载

    前段时间莫名其妙的发现发布的app不能正常的现实图标和启动页了,加载出来的图标以及图片显示的都是cordova的默认图片以及启动页图片 在网上找了很多教程各种查找都不能解决方法 表现原因为: 项目根目 ...

  2. 【IOS】模仿"抽屉新热榜"动态启动页YFSplashScreen

    IOS最好要设置系统默认启动页面,不然进入应用就会突然闪现黑色画面 下图是我们要实现的效果: 总体思路:设置一个系统默认启动页面,在进入didFinishLaunchingWithOptions时, ...

  3. ASP.NET MVC 设置Area中 Controller 的方法 默认启动页

    MVC中通常分区域编程,互不干扰,如果需要设置某个区域下面的某个控制器下面的某个方法为默认启动页的话,直接修改项目的路由如下: public static void RegisterRoutes(Ro ...

  4. iOS-上架APP之启动页设置(新手必看!)

    今天自己做的小作品准备提交,就差一个启动页,各种百度,各种搜,结果还好最后终于出来了,和大家分享一下,这个过程中遇到的各种小问题.(注XCode版本为7.2) 1.启动页一般都是图片,因为苹果有4,4 ...

  5. iOS-LaunchImage启动页

    一. 目标: 设置一个漂亮的启动页. 二.步骤 1. 先创建LaunchImage 2. 进一步设置需要适配的启动页机型 3. 设置完成的效果 4.往里面拖图片,如图是适配的图片的配置 5. 在项目中 ...

  6. [摘抄]iOS App icon、启动页、图标规范

    以下内容都是我在做App时通过自己的经验和精品的分析得来的,希望会帮助到你.但是有时个别情况也要个别分析,要活学活用. 一. App  Icon 在设计iOS App Icon时,设计师不需要切圆角, ...

  7. iOS启动页设置

    点击项目->TARGETS->App Icons and Launch Images->Launch Images Source->Use Asset Catalog...-& ...

  8. iOS关于启动页自定义特殊处理

    平常开发中对于启动页可能会有一些特别的要求,比如在启动页加动画或加一些按键可以响应事件等,最近项目中要在启动页增加版本号,因为版本号是不断的改变,所以要动态实现把它加到启动页上:在XCode上面配置的 ...

  9. swift——启动页国际化:一步一步动态加载启动页图片,启动的时候加载文字

    由于公司的需求,要求做一个国际化的启动页,因为app我也弄国际化了,就剩下启动页国际化未完成,百度了呵谷歌了好多答案都不尽如人意,最后也是看见同事完成,我也问了具体的做法,决定分享给需要的人,免得和我 ...

随机推荐

  1. eureka源码--服务的注册、服务续约、服务发现、服务下线、服务剔除、定时任务以及自定义注册中心的思路

    微服务注册后,在注册中心的注册表结构是一个map: ConcurrentHashMap<String, Map<String, Lease<InstanceInfo>>& ...

  2. Raft 协议

    Paxos 存在的问题 Paxos 算法的描述偏学术化,缺失了很多细节,无法直接应用于工程领域.实际工程应用中的分布式算法大多是 Paxos 的变种,验证这些算法的正确性也成为了一个难题. 举个例子: ...

  3. 03 以Hello World为例,分析C语言的最小的程序结构

    C程序主要包含的部分 预处理器指令 函数 变量 语句 & 表达式 注释 C Hello World 实例 如下程序,可以在屏幕输出短句"Hello World" #incl ...

  4. python排序算法总结和实现

    ------------------希尔排序------------- 一直没搞懂希尔排序怎么搞得 def Shell_sort(L): step = len(L)/2 while step > ...

  5. matlab中num2str 将数字转换为字符数组

    参考:https://ww2.mathworks.cn/help/matlab/ref/num2str.html?searchHighlight=num2str&s_tid=doc_srcht ...

  6. 【题解】[APIO2010]特别行动队

    Link 题目大意:一段区间的贡献是\(ax^2+bx+c,x=\sum v\),求一个划分让总区间的价值最大.分段必须连续. \(\text{Solution:}\) 设计\(dp[i]\)表示前\ ...

  7. Hive理论基础

    数仓特征:面向主题,集成,非易失的,时变.数据仓库是在数据库已经大量存在的情况下,为了进一步挖掘数据资源.为了决策需要而产生的,不是所谓的"大型数据库".   数据库与数据仓库的区 ...

  8. Codeforces Global Round 11 个人题解(B题)

    Codeforces Global Round 11 1427A. Avoiding Zero 题目链接:click here 待补 1427B. Chess Cheater 题目链接:click h ...

  9. 笔记本键盘按U键却变成了4

    解答 笔记本键盘U盘变成了4,是因为你开启了小键盘功能.出现该问题,只要关闭小键盘功能即可,操作如下: 按住键盘下方的Fn,同时按住键盘顶部的F键中标有Numlk的键. 电脑屏幕出现解锁标志,小键盘功 ...

  10. elasticsearch要点及常用查询

    目录 elasticsearch要点及常用查询 查询与过滤 明确查询和过滤各自的优缺点,以及适用场景. 性能上的差异 适用场景 1.kibana 中操作es-查询 Mapping映射基础 mappin ...