欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android UI設(shè)計與開發(fā)之使用ViewPager實現(xiàn)歡迎引導(dǎo)頁面

 更新時間:2017年08月30日 10:44:57   作者:yangyu20121224  
這篇文章主要為大家詳細介紹了Android UI設(shè)計與開發(fā)之使用ViewPager實現(xiàn)歡迎引導(dǎo)頁面,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本系列文章都會以一個程序的實例開發(fā)為主線來進行講解,以求達到一個循序漸進的學(xué)習(xí)效果,這樣更能加深大家對于程序為什么要這樣寫的用意,理論加上實際的應(yīng)用才能達到事半功倍的效果,不是嗎?

最下方有源碼的下載地址,幾乎源碼的每一行都有注釋,寫的通俗易懂,非常清晰,如有不懂的可以留言,本博主一定盡心盡力,為大家答題解惑,希望大家多多支持,好的,話不多說,讓我們回歸到今天的正題。

一、實現(xiàn)的效果圖

也許是養(yǎng)成了這樣一個習(xí)慣,每次看別人的代碼前,必須要先看實現(xiàn)的效果圖達到了一個什么樣的效果,是不是跟自己想要實現(xiàn)的效果類似,有圖才有真相嘛,呵呵。



二、編碼前的準(zhǔn)備工作

 ViewPager是Android3.0之后提供的新特性,所以要想讓你的應(yīng)用向下兼容就必須要Android-support-v4.jar這個包的支持,這是一個來自google提供的一個附加包。大家搜下即可。

三、項目結(jié)構(gòu)圖

四、具體的編碼實現(xiàn)

1、  布局界面比較簡單,加入ViewPager組件,以及底部的引導(dǎo)小點,activity_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/viewpager" 
 android:layout_width="fill_parent" 
 android:layout_height="fill_parent" /> 
 
 <LinearLayout 
 android:id="@+id/ll" 
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" 
 android:layout_alignParentBottom="true" 
 android:layout_centerHorizontal="true" 
 android:layout_marginBottom="24.0dip" 
 android:orientation="horizontal"> 
 
 <ImageView 
  android:layout_width="wrap_content" 
  android:layout_height="wrap_content" 
  android:layout_gravity="center_vertical" 
  android:clickable="true" 
  android:padding="15.0dip" 
  android:src="@drawable/point"/> 
 <ImageView 
  android:layout_width="wrap_content" 
  android:layout_height="wrap_content" 
  android:layout_gravity="center_vertical" 
  android:clickable="true" 
  android:padding="15.0dip" 
  android:src="@drawable/point"/> 
 <ImageView 
  android:layout_width="wrap_content" 
  android:layout_height="wrap_content" 
  android:layout_gravity="center_vertical" 
  android:clickable="true" 
  android:padding="15.0dip" 
  android:src="@drawable/point"/> 
 <ImageView 
  android:layout_width="wrap_content" 
  android:layout_height="wrap_content" 
  android:layout_gravity="center_vertical" 
  android:clickable="true" 
  android:padding="15.0dip" 
  android:src="@drawable/point"/> 
 </LinearLayout> 
</RelativeLayout> 

 2、其中小點的圖片用一個selector來控制顏色,point.xml:

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

3、 ViewPager適配器代碼,ViewPagerAdapter.java:

package com.yangyu; 
 
import java.util.ArrayList; 
 
import android.support.v4.view.PagerAdapter; 
import android.support.v4.view.ViewPager; 
import android.view.View; 
 
/** 
 * @author yangyu 
 * 功能描述:ViewPager適配器,用來綁定數(shù)據(jù)和view 
 */ 
public class ViewPagerAdapter extends PagerAdapter { 
 
 //界面列表 
 private ArrayList<View> views; 
 
 public ViewPagerAdapter (ArrayList<View> views){ 
 this.views = views; 
 } 
  
 /** 
 * 獲得當(dāng)前界面數(shù) 
 */ 
 @Override 
 public int getCount() { 
  if (views != null) { 
  return views.size(); 
  } 
  return 0; 
 } 
 
 /** 
 * 初始化position位置的界面 
 */ 
 @Override 
 public Object instantiateItem(View view, int position) { 
  
 ((ViewPager) view).addView(views.get(position), 0); 
  
 return views.get(position); 
 } 
 
 /** 
 * 判斷是否由對象生成界面 
 */ 
 @Override 
 public boolean isViewFromObject(View view, Object arg1) { 
 return (view == arg1); 
 } 
 
 /** 
 * 銷毀position位置的界面 
 */ 
 @Override 
 public void destroyItem(View view, int position, Object arg2) { 
 ((ViewPager) view).removeView(views.get(position));  
 } 
}

 4、主程序入口類,MainActivity.java:

package com.yangyu; 
 
import java.util.ArrayList; 
 
import android.app.Activity; 
import android.os.Bundle; 
import android.support.v4.view.ViewPager; 
import android.support.v4.view.ViewPager.OnPageChangeListener; 
import android.view.View; 
import android.view.View.OnClickListener; 
import android.widget.ImageView; 
import android.widget.LinearLayout; 
 
import com.example.myguideview01.R; 
 
/** 
 * @author yangyu 
 * 功能描述:主程序入口類 
 */ 
public class MainActivity extends Activity implements OnClickListener,OnPageChangeListener { 
 //定義ViewPager對象 
 private ViewPager viewPager; 
 
 //定義ViewPager適配器 
 private ViewPagerAdapter vpAdapter; 
 
 //定義一個ArrayList來存放View 
 private ArrayList<View> views; 
 
 //引導(dǎo)圖片資源 
 private static final int[] pics = {R.drawable.guide1,R.drawable.guide2,R.drawable.guide3,R.drawable.guide4}; 
 
 //底部小點的圖片 
 private ImageView[] points; 
 
 //記錄當(dāng)前選中位置 
 private int currentIndex; 
 
 @Override 
 protected void onCreate(Bundle savedInstanceState) { 
 super.onCreate(savedInstanceState); 
 setContentView(R.layout.activity_main); 
  
 initView(); 
  
 initData(); 
 } 
 
 /** 
 * 初始化組件 
 */ 
 private void initView(){ 
 //實例化ArrayList對象 
 views = new ArrayList<View>(); 
  
 //實例化ViewPager 
 viewPager = (ViewPager) findViewById(R.id.viewpager); 
  
 //實例化ViewPager適配器 
 vpAdapter = new ViewPagerAdapter(views); 
 } 
 
 /** 
 * 初始化數(shù)據(jù) 
 */ 
 private void initData(){ 
 //定義一個布局并設(shè)置參數(shù) 
 LinearLayout.LayoutParams mParams = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.FILL_PARENT, 
          LinearLayout.LayoutParams.FILL_PARENT); 
  
 //初始化引導(dǎo)圖片列表 
 for(int i=0; i<pics.length; i++) { 
  ImageView iv = new ImageView(this); 
  iv.setLayoutParams(mParams); 
  iv.setImageResource(pics[i]); 
  views.add(iv); 
 } 
  
 //設(shè)置數(shù)據(jù) 
 viewPager.setAdapter(vpAdapter); 
 //設(shè)置監(jiān)聽 
 viewPager.setOnPageChangeListener(this); 
  
 //初始化底部小點 
 initPoint(); 
 } 
 
 /** 
 * 初始化底部小點 
 */ 
 private void initPoint(){ 
 LinearLayout linearLayout = (LinearLayout) findViewById(R.id.ll);  
  
 points = new ImageView[pics.length]; 
 
 //循環(huán)取得小點圖片 
 for (int i = 0; i < pics.length; i++) { 
  //得到一個LinearLayout下面的每一個子元素 
  points[i] = (ImageView) linearLayout.getChildAt(i); 
  //默認都設(shè)為灰色 
  points[i].setEnabled(true); 
  //給每個小點設(shè)置監(jiān)聽 
  points[i].setOnClickListener(this); 
  //設(shè)置位置tag,方便取出與當(dāng)前位置對應(yīng) 
  points[i].setTag(i); 
 } 
  
 //設(shè)置當(dāng)面默認的位置 
 currentIndex = 0; 
 //設(shè)置為白色,即選中狀態(tài) 
 points[currentIndex].setEnabled(false); 
 } 
 
 /** 
 * 當(dāng)滑動狀態(tài)改變時調(diào)用 
 */ 
 @Override 
 public void onPageScrollStateChanged(int arg0) { 
 
 } 
 
 /** 
 * 當(dāng)當(dāng)前頁面被滑動時調(diào)用 
 */ 
 
 @Override 
 public void onPageScrolled(int arg0, float arg1, int arg2) { 
 
 } 
 
 /** 
 * 當(dāng)新的頁面被選中時調(diào)用 
 */ 
 
 @Override 
 public void onPageSelected(int position) { 
 //設(shè)置底部小點選中狀態(tài) 
 setCurDot(position); 
 } 
 
 /** 
 * 通過點擊事件來切換當(dāng)前的頁面 
 */ 
 @Override 
 public void onClick(View v) { 
  int position = (Integer)v.getTag(); 
  setCurView(position); 
  setCurDot(position);  
 } 
 
 /** 
 * 設(shè)置當(dāng)前頁面的位置 
 */ 
 private void setCurView(int position){ 
  if (position < 0 || position >= pics.length) { 
  return; 
  } 
  viewPager.setCurrentItem(position); 
 } 
 
 /** 
 * 設(shè)置當(dāng)前的小點的位置 
 */ 
 private void setCurDot(int positon){ 
  if (positon < 0 || positon > pics.length - 1 || currentIndex == positon) { 
  return; 
  } 
  points[positon].setEnabled(false); 
  points[currentIndex].setEnabled(true); 
 
  currentIndex = positon; 
 } 
} 

這篇主要是讓大家能夠?qū)崿F(xiàn)一個簡單的例子,讓你的程序先動起來,才有信心和勇氣挑戰(zhàn)更復(fù)雜的UI設(shè)計和開發(fā),在后面的幾篇章節(jié)中,博主也會以同樣生動和富有激情的講解,給大家?guī)砀拥膹?fù)雜的演示和代碼,如仿微信、和人人網(wǎng)的引導(dǎo)界面的開發(fā),加入了動畫的效果,運行起來也會更炫一點。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Android實現(xiàn)動畫效果詳解

    Android實現(xiàn)動畫效果詳解

    這篇文章主要介紹了Android實現(xiàn)動畫效果詳解,目前Android平臺提供了Tween動畫和Frame動畫,實現(xiàn)這兩類動畫有兩種方式:一種使用XML文件(文件放在res/anim),一種直接代碼搞定,需要的朋友可以參考下
    2015-07-07
  • Android中shape定義控件的使用

    Android中shape定義控件的使用

    Android中常常使用shape來定義控件的一些顯示屬性,接下來通過本篇文章給大家介紹Android中shape定義控件的使用,對android shape定義控件相關(guān)知識感興趣的朋友一起學(xué)習(xí)吧
    2016-01-01
  • Android 密碼 顯示與隱藏功能實例

    Android 密碼 顯示與隱藏功能實例

    這篇文章主要介紹了Android 密碼 顯示與隱藏功能實例,需要的朋友可以參考下
    2017-06-06
  • android Activity線性布局和表格布局實例講解

    android Activity線性布局和表格布局實例講解

    在activity的布局中,線性布局和表格布局是最簡單的,這次分別從線性布局,表格布局以及線性布局和表格混合布局做了實驗
    2013-11-11
  • Android中使用sax解析xml文件的方法

    Android中使用sax解析xml文件的方法

    本篇文章介紹了,在Android中使用sax解析xml文件的方法。需要的朋友參考下
    2013-04-04
  • Android使用Notification實現(xiàn)寬視圖通知欄(二)

    Android使用Notification實現(xiàn)寬視圖通知欄(二)

    這篇文章主要為大家詳細介紹了Android使用Notification實現(xiàn)寬視圖通知欄,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • android實現(xiàn)打地鼠游戲

    android實現(xiàn)打地鼠游戲

    這篇文章主要為大家詳細介紹了android實現(xiàn)打地鼠游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • 自定義視圖view之環(huán)形進度條

    自定義視圖view之環(huán)形進度條

    這篇文章主要介紹了自定義視圖view之環(huán)形進度條,這次介紹了4種不同的效果,直接上代碼了,需要的朋友可以參考下
    2023-04-04
  • Android利用SAX對XML進行增刪改查操作詳解

    Android利用SAX對XML進行增刪改查操作詳解

    在項目中會遇到對于XML的增刪改查,下面這篇文章主要給大家介紹了關(guān)于Android利用SAX對XML進行增刪改查操作的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-01-01
  • Android中Service的全面總結(jié)

    Android中Service的全面總結(jié)

    這篇文章主要全面總結(jié)了Android中Service的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06

最新評論