Android开发之滑动图片轮播标题焦点

时间:2021-05-20

先给大家这是下效果图:

谷歌提供的v4包,ViewPager

在布局文件中,先添加<android.support.v4.view.ViewPager/>控件,这个只是轮播的区域

在布局文件中,布置标题描述部分

线性布局,竖向排列,背景色黑色半透明,这个布局和上面的ViewPager底部对齐layout_alignBottom=”@id/xxx”

<TextView/>居中显示,

小点部分,先放过空的LinearLayout,id是ll_points在代码中对其进行填充

获取ViewPager对象

调用ViewPager对象的setAdapter()方法,参数:PagerAdapter对象

因为PagerAdapter是抽象类,定义一个MyPagerAdapter继承PagerAdapter,实现以下方法

重写getCount()方法,返回轮播的个数

重写isViewFromObject()方法,返回布尔值,

重写instantiateItem()方法,将当前view对象添加到ViewGroup对象,返回当前对象

重写destroyItem()方法,从当前container中删除指定位置(position)的View

切换描述标题字符串

定义一个String[]数组,保存标题

调用ViewPager对象的setOnPagerChangeListener()方法,参数:OnPagerChangeListener对象

匿名内部类实现,重写以下方法

onPageSelected()方法,页面切换后调用,传递进参数,int索引

onPageScrolled()方法,当页面正在滚动的时候

onPageScrollStateChanged()方法,当页面滚动状态改变的时候

小图标部分

新建两个shape文件,使用xml画两个原点

添加节点<shape>,设置形状为原型android:shape=”oval”

添加尺寸节点<size> ,设置宽度,高度,android:width=”” android:height=””

添加颜色节点<solid>,设置颜色 android:color=””

正常情况下,灰色点,焦点的时候,白色的点,两个xm文件的颜色不一样

point.xml

<?xml version="1.0" encoding="utf-8"?><shape xmlns:android="http://schemas.android.com/apk/res/android"android:shape="oval" ><sizeandroid:height="4dp"android:width="4dp" /><solid android:color="#aaffffff"/></shape>

point_write.xml

<?xml version="1.0" encoding="utf-8"?><shape xmlns:android="http://schemas.android.com/apk/res/android"android:shape="oval" ><sizeandroid:height="4dp"android:width="4dp" /><solid android:color="#ffffffff"/></shape>

新建一个selector文件,当图片enable的时候白色的点,不可用的时候灰色的点,不同的状态不同的图片

添加<selector>节点

添加<item>节点,设置图片属性android:drawable=”” 设置状态android:enabled=”true|false”

point_selector.xml

<?xml version="1.0" encoding="utf-8"?><selector xmlns:android="http://schemas.android.com/apk/res/android" ><item android:drawable="@drawable/point" android:state_enabled="false"></item><item android:drawable="@drawable/point_write" android:state_enabled="true"></item></selector>

循环大图片的个数,创建ImageView对象,

调用ImageView对象setImageResource()方法,设置资源,参数:selector文件

调用ImageView对象的setLayoutParams()方法,给小图标ImageView对象添加一些margin值,参数:LayoutParams对象,获取LinearLayout.LayoutParams对象,调用LayoutParams对象的rightMargin()方法,设置margin值

调用ImageView对象的setEnabled()方法,设置是否可用,参数:布尔值

获取LinearLayout对象,调用LinearLayout对象的addView()方法,把小图标的视图填进去,参数:ImageView对象

默认第一个是焦点,随着图片滑动,焦点跟着改变

package com.tsh.myviewpager;import java.util.ArrayList;import java.util.List;import android.app.Activity;import android.os.Bundle;import android.support.v.view.PagerAdapter;import android.support.v.view.ViewPager;import android.support.v.view.ViewPager.OnPageChangeListener;import android.view.View;import android.view.ViewGroup;import android.widget.ImageView;import android.widget.LinearLayout;import android.widget.TextView;public class MainActivity extends Activity {private ViewPager vp_banner;private LinearLayout ll_points;private TextView tv_title;private List<View> banners;private String[] titles=new String[]{"新闻标题","新闻标题","新闻标题"};private List<ImageView> points=new ArrayList<ImageView>();@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);// 初始化vp_banner = (ViewPager) findViewById(R.id.vp_banner);ll_points = (LinearLayout) findViewById(R.id.ll_points);tv_title = (TextView) findViewById(R.id.tv_title);// banner部分banners = new ArrayList<>();ImageView img = new ImageView(this);img.setImageResource(R.drawable.a);banners.add(img);ImageView img = new ImageView(this);img.setImageResource(R.drawable.b);banners.add(img);ImageView img = new ImageView(this);img.setImageResource(R.drawable.c);banners.add(img);//小图标ll_points=(LinearLayout) findViewById(R.id.ll_points);for(int i=;i<banners.size();i++){ImageView image=new ImageView(this);image.setImageResource(R.drawable.point_selector);LinearLayout.LayoutParams params=new LinearLayout.LayoutParams(, );params.rightMargin=;image.setLayoutParams(params);ll_points.addView(image);if(i==){image.setEnabled(true);}else{image.setEnabled(false);}points.add(image);}// 设置适配器vp_banner.setAdapter(new MyPagerAdapter());vp_banner.setOnPageChangeListener(new OnPageChangeListener() {@Overridepublic void onPageSelected(int arg) {tv_title.setText(titles[arg]);//小图标处理for(ImageView point:points){point.setEnabled(false);}points.get(arg).setEnabled(true);}@Overridepublic void onPageScrolled(int arg, float arg, int arg) {// TODO Auto-generated method stub}@Overridepublic void onPageScrollStateChanged(int arg) {// TODO Auto-generated method stub}});}private class MyPagerAdapter extends PagerAdapter {@Overridepublic void destroyItem(ViewGroup container, int position, Object object) {container.removeView(banners.get(position));}@Overridepublic Object instantiateItem(ViewGroup container, int position) {container.addView(banners.get(position));return banners.get(position);}@Overridepublic int getCount() {return banners.size();}@Overridepublic boolean isViewFromObject(View arg, Object arg) {return arg == arg;}}}

以上所述是小编给大家介绍的Android开发之滑动图片轮播标题焦点的相关知识,希望对大家有所帮助!

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章