Android引導(dǎo)頁(yè)面的簡(jiǎn)單實(shí)現(xiàn)
第一次進(jìn)入應(yīng)用的時(shí)候,都會(huì)有一個(gè)引導(dǎo)頁(yè)面,引導(dǎo)頁(yè)面的實(shí)現(xiàn)起來(lái)也很簡(jiǎn)單,實(shí)現(xiàn)的方式也有很多,下面是自己寫(xiě)的一個(gè)引導(dǎo)頁(yè)面的效果,大致的實(shí)現(xiàn)思路為:
最外層是一個(gè)FragmentActivity,里面包含4個(gè)fragment,在fragment中給ViewPager開(kāi)一個(gè)循環(huán),這樣實(shí)現(xiàn)了圖片播,其實(shí)效果就是在FragmentActivity中幾個(gè)fragment滑動(dòng)切換,
fragment中ViewPager無(wú)限輪播和滑動(dòng)切換;
下面為代碼實(shí)現(xiàn):
public class MainActivity extends ActionBarActivity {
private ViewPager viewpager;
private FragmentManager fm;
private ViewPagerAdapter adapter;
private ArrayList<Object> items = new ArrayList<Object>();
private Button btn_guide;
private View point1, point2, point3, point4;
private int choiceBg = R.drawable.shape_bule_point;// 被選背景
private int unChoiceBg = R.drawable.shape_center_point_red;// 未被選背景
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.activity_main);
initView();
}
private void initView() {
btn_guide = (Button) findViewById(R.id.btn_guide);
point1 = findViewById(R.id.point1);
point2 = findViewById(R.id.point2);
point3 = findViewById(R.id.point3);
point4 = findViewById(R.id.point4);
viewpager = (ViewPager) findViewById(R.id.viewpager);
fm = this.getSupportFragmentManager();
items.add(new FirstFragment());
items.add(new SecondFragment());
items.add(new ThridFragment());
items.add(new FourFragment());
adapter = new ViewPagerAdapter(fm, items);
viewpager.setAdapter(adapter);
viewpager.setCurrentItem(0, false);
viewpager.setOffscreenPageLimit(items.size());
// 被選設(shè)置為藍(lán)色
point1.setBackgroundResource(choiceBg);
viewpager.setOnPageChangeListener(new GuidePageListener());
}
/**
* viewpager的滑動(dòng)監(jiān)聽(tīng)
*
* @author Kevin
*
*/
class GuidePageListener implements OnPageChangeListener {
// 滑動(dòng)事件
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
}
// 某個(gè)頁(yè)面被選中
@Override
public void onPageSelected(int position) {
if (position == 0) {
setPointBg(choiceBg, unChoiceBg, unChoiceBg, unChoiceBg);
} else if (position == 1) {
setPointBg(unChoiceBg, choiceBg, unChoiceBg, unChoiceBg);
} else if (position == 2) {
setPointBg(unChoiceBg, unChoiceBg, choiceBg, unChoiceBg);
} else {
setPointBg(unChoiceBg, unChoiceBg, unChoiceBg, choiceBg);
}
if (position == items.size() - 1) {// 最后一個(gè)頁(yè)面
btn_guide.setVisibility(View.VISIBLE);// 顯示開(kāi)始體驗(yàn)的按鈕
} else {
btn_guide.setVisibility(View.INVISIBLE);
}
}
// 滑動(dòng)狀態(tài)發(fā)生變化
@Override
public void onPageScrollStateChanged(int state) {
}
}
/**
* 設(shè)置被選小圓點(diǎn)的背景顏色
*
* @param pointBg1
* @param pointBg2
* @param pointBg3
* @param pointBg4
*/
private void setPointBg(int pointBg1, int pointBg2, int pointBg3, int pointBg4) {
point1.setBackgroundResource(pointBg1);
point2.setBackgroundResource(pointBg2);
point3.setBackgroundResource(pointBg3);
point4.setBackgroundResource(pointBg4);
}
}
在這里要注意ViewPager和fragment在滑動(dòng)變化時(shí),改變底部小圓點(diǎn)被選的顏色;
public class HomeAdapter extends PagerAdapter {
private List<GuiderInfo> data;
private ImageCycleViewListener mImageCycleViewListener;
private Context context;
public HomeAdapter(Context context, List<GuiderInfo> data, ImageCycleViewListener mImageCycleViewListener) {
this.context = context;
this.mImageCycleViewListener = mImageCycleViewListener;
this.data = new ArrayList<GuiderInfo>();
if (data != null) {
this.data.addAll(data);
}
}
public void notifyData(List<GuiderInfo> data) {
if (data != null) {
this.data.clear();
this.data.addAll(data);
}
notifyDataSetChanged();
}
// 當(dāng)天viewpager有多少個(gè)條目
LinkedList<ImageView> imageList = new LinkedList<ImageView>();
@Override
public int getCount() {
if (data.size() != 0) {
return Integer.MAX_VALUE;// 無(wú)限循環(huán)
} else {
return 0;
}
}
// 判斷返回的對(duì)象和加載view對(duì)象關(guān)系
@Override
public boolean isViewFromObject(View arg0, Object arg1) {
return arg0 == arg1;
}
// 銷(xiāo)毀一個(gè)條目
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
// super.destroyItem(container, position, object);
ImageView view = (ImageView) object;
imageList.add(view);// 把移除的對(duì)象添加到緩存集合中
container.removeView(view);
}
// 創(chuàng)建一個(gè)條目
@Override
public Object instantiateItem(ViewGroup container, int position) {
int index = 0;
if (data.size() != 0) {
index = position % data.size();
}
final ImageView image;
if (imageList.size() > 0) {
image = imageList.remove(0);
} else {
image = new ImageView(context);
}
// BitmapUtils bitmapUtils = BitMapHelper.getBitmapUtils();
final GuiderInfo vo = data.get(index);
if (vo != null) {
// String url = vo.url;
// bitmapUtils.display(image, url, new BitmapLoadCallBack<View>() {
//
// @SuppressWarnings("deprecation")
// @Override
// public void onLoadCompleted(View arg0, String arg1, Bitmap bitmap, BitmapDisplayConfig arg3, BitmapLoadFrom arg4) {
// image.setImageBitmap(null);
// BitmapDrawable ob = new BitmapDrawable(context.getResources(), bitmap);
// image.setBackgroundDrawable(ob);
// }
//
// @Override
// public void onLoadFailed(View arg0, String arg1, Drawable arg2) {
// // TODO Auto-generated method stub
//
// }
// });
int imageid = vo.imageid;
image.setImageResource(imageid);
// bitmapUtils.display(image, url);
}
final int pos = index;
if (mImageCycleViewListener != null) {
image.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
mImageCycleViewListener.onImageClick(vo, pos, image);
}
});
}
container.addView(image);// 加載的view對(duì)象
return image;// 返回的對(duì)象
}
/**
* 輪播控件的監(jiān)聽(tīng)事件
*
* @author minking
*/
public static interface ImageCycleViewListener {
/**
* 單擊圖片事件
*
* @param position
* @param imageView
*/
public void onImageClick(GuiderInfo info, int postion, View imageView);
}
}
public class FirstFragment extends Fragment implements ImageCycleViewListener {
private View view;
private ViewPager header_view;
private HomeAdapter adapter;
private List<GuiderInfo> data = new ArrayList<GuiderInfo>();
private boolean flag;
private TextView tv_dis;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
view = inflater.inflate(R.layout.first_fragment, container, false);
setData();
initView();
return view;
}
@SuppressWarnings("deprecation")
private void initView() {
tv_dis = (TextView) view.findViewById(R.id.tv_dis);
header_view = (ViewPager) view.findViewById(R.id.header_view);
adapter = new HomeAdapter(getActivity(), data, this);
header_view.setAdapter(adapter);
header_view.setOnPageChangeListener(new OnPageChangeListener() {
@Override
public void onPageSelected(int arg0) {
//計(jì)算當(dāng)前選中的圖片index
int index = arg0 % 2;
System.out.println("-----------index" + index);
GuiderInfo dtGzsApplyCenterHeader = data.get(index);
tv_dis.setText(""+dtGzsApplyCenterHeader.event_content);
}
@Override
public void onPageScrolled(int arg0, float arg1, int arg2) {
}
@Override
public void onPageScrollStateChanged(int arg0) {
}
});
// 設(shè)置中間值
final AuToRunTask run = new AuToRunTask();
header_view.setCurrentItem(1000 * data.size());// 實(shí)現(xiàn)左右兩邊都可以滑動(dòng)
header_view.setOnTouchListener(new OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:// 按下
run.stop();
break;
case MotionEvent.ACTION_CANCEL:// 事件取消
case MotionEvent.ACTION_UP:// 抬起
run.start();
break;
default:
break;
}
return false;// viewpager觸摸事件返回值要是fasle不能為true
}
});
run.start();// 開(kāi)啟輪播
}
@Override
public void onImageClick(GuiderInfo info, int postion, View imageView) {
}
// 自動(dòng)輪播
class AuToRunTask implements Runnable {
@Override
public void run() {
if (flag) {
// 取消之前的任務(wù)
DensityUtil.cancle(this);
// 獲取當(dāng)前條目
int currentItem = header_view.getCurrentItem();
currentItem++;
header_view.setCurrentItem(currentItem);
// 延遲執(zhí)行當(dāng)前的一個(gè)任務(wù)
DensityUtil.postDelayed(this, 2000);// 遞歸調(diào)用
}
}
public void start() {
if (!flag) {
// 取消之前的任務(wù)
DensityUtil.cancle(this);
flag = true;
// 延遲執(zhí)行當(dāng)前的一個(gè)任務(wù)
DensityUtil.postDelayed(this, 1000);// 遞歸調(diào)用
}
}
public void stop() {
if (flag) {
flag = false;
DensityUtil.cancle(this);
}
}
}
private void setData() {
GuiderInfo vo = new GuiderInfo();
vo.imageid = R.drawable.shape_red;
vo.event_content="紅色";
data.add(vo);
GuiderInfo vo1 = new GuiderInfo();
vo1.imageid = R.drawable.shape_yellow;
vo1.event_content="黃色";
data.add(vo1);
}
}
以上為效果實(shí)現(xiàn)的主要代碼,效果運(yùn)行如下:

上面的效果圖還有一小部分效果未展示出來(lái),其實(shí)上面的圓是循環(huán)輪播的,同時(shí)也是可以滑動(dòng)的;
源碼:Androidpager
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android實(shí)現(xiàn)過(guò)渡動(dòng)畫(huà)、引導(dǎo)頁(yè) Android判斷是否第一次啟動(dòng)App
- Android使用ViewPager實(shí)現(xiàn)啟動(dòng)引導(dǎo)頁(yè)
- Android開(kāi)發(fā)實(shí)戰(zhàn)之漂亮的ViewPager引導(dǎo)頁(yè)
- Android開(kāi)發(fā)實(shí)現(xiàn)的ViewPager引導(dǎo)頁(yè)功能(動(dòng)態(tài)加載指示器)詳解
- Android控件ViewPager實(shí)現(xiàn)帶有動(dòng)畫(huà)的引導(dǎo)頁(yè)
- Android實(shí)現(xiàn)繞球心旋轉(zhuǎn)的引導(dǎo)頁(yè)效果
- Android實(shí)現(xiàn)漸變啟動(dòng)頁(yè)和帶有指示器的引導(dǎo)頁(yè)
- RxJava兩步打造華麗的Android引導(dǎo)頁(yè)
- Android自定義控件打造絢麗平行空間引導(dǎo)頁(yè)
- Android簡(jiǎn)單實(shí)現(xiàn)引導(dǎo)頁(yè)
相關(guān)文章
Android下載進(jìn)度監(jiān)聽(tīng)和通知的處理詳解
這篇文章主要為大家詳細(xì)介紹了Android下載進(jìn)度監(jiān)聽(tīng)和通知的處理,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08
Android懸浮對(duì)話(huà)框(即點(diǎn)即關(guān)對(duì)話(huà)框)實(shí)現(xiàn)代碼
本文給大家介紹android懸浮對(duì)話(huà)框和即點(diǎn)即關(guān)閉對(duì)話(huà)框,本文介紹非常詳細(xì),具有參考借鑒價(jià)值,感興趣的朋友一起學(xué)習(xí)吧2016-03-03
Android Shader應(yīng)用開(kāi)發(fā)之霓虹閃爍文字效果
這篇文章主要為大家詳細(xì)介紹了Android Shader應(yīng)用開(kāi)發(fā)之霓虹閃爍文字效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07
Android Dialog 動(dòng)畫(huà)實(shí)例詳解
這篇文章主要介紹了Android Dialog 動(dòng)畫(huà)實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-04-04
React?Native之在A(yíng)ndroid上添加陰影的實(shí)現(xiàn)
這篇文章主要介紹了React?Native之在A(yíng)ndroid上添加陰影的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03
SurfaceView開(kāi)發(fā)[捉小豬]手機(jī)游戲 (二)
這篇文章主要介紹了用SurfaceView開(kāi)發(fā)[捉小豬]手機(jī)游戲 (二)本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-08-08
Android通過(guò)實(shí)現(xiàn)GridView的橫向滾動(dòng)實(shí)現(xiàn)仿京東秒殺效果
這篇文章主要介紹了Android通過(guò)實(shí)現(xiàn)GridView的橫向滾動(dòng)實(shí)現(xiàn)仿京東秒殺效果,實(shí)現(xiàn)代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-07-07

