ViewPager類(lèi)提供了多界面切換的新效果。新效果有如下特征:
[1] 當(dāng)前顯示一組界面中的其中一個(gè)界面。
[2] 當(dāng)用戶(hù)通過(guò)左右滑動(dòng)界面時(shí),當(dāng)前的屏幕顯示當(dāng)前界面和下一個(gè)界面的一部分。
[3] 滑動(dòng)結(jié)束后,界面自動(dòng)跳轉(zhuǎn)到當(dāng)前選擇的界面中
ViewPager來(lái)源于google 的補(bǔ)充組件android-support-v4.jar,位置在androidSDK文件夾
android-sdks\extras\android\support\ 下
將android-support-v4.jar 引用到項(xiàng)目中
注:該包需要在Android SDK Manager中額外下載Extras下的Android Support package,
或直接下載該jar包到項(xiàng)目中引用
引入后可直接當(dāng)作控件在項(xiàng)目中使用。
配置文件頁(yè)面文件
<android.support.v4.view.ViewPager
android:id="@+id/viewPager1"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_centerVertical="true" />
配置適配器的頁(yè)面變化事件
viewPager1.setOnPageChangeListener(new OnPageChangeListener() {
//頁(yè)面選擇
@Override
public void onPageSelected(int position) {
topText.setText(String.valueOf(position+1)+"/"+String.valueOf(lists.length));
}
@Override
public void onPageScrollStateChanged(int state) { }
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) { }
});
ViewPager使用的適配器基于PagerAdapter基類(lèi)
主要實(shí)現(xiàn)一下四個(gè)方法
//獲取當(dāng)前窗體界面數(shù)
public int getCount()
//初始化position位置的界面
public Object instantiateItem(View collection, int position)
//銷(xiāo)毀position位置的界面
public void destroyItem(View collection, int position, Object view)
// 判斷是否由對(duì)象生成界面
public boolean isViewFromObject(View arg0, Object arg1)
ViewPager控件的使用中,可以將View裝如ArrayList中作為數(shù)據(jù)載體,每一項(xiàng)(即每一頁(yè))
為一個(gè)View顯示,可以適應(yīng)大量頁(yè)面或者變化的頁(yè)面長(zhǎng)度的顯示
Viewfilpper控件主要用于在同一個(gè)Activity內(nèi)屏幕見(jiàn)的切換,最長(zhǎng)見(jiàn)的情況就是在一個(gè)FrameLayout內(nèi)有多個(gè)頁(yè)面,比如一個(gè)系統(tǒng)設(shè)置頁(yè)面;一個(gè)個(gè)性化設(shè)置頁(yè)面。
ViewFilpper控件是系統(tǒng)自帶控件之一,主要是為兩個(gè)頁(yè)面間的切換設(shè)置動(dòng)畫(huà)效果。ViewFilpper繼承自FrameLayout下的ViewAnimator,
android.widget.ViewAnimator類(lèi)繼承至FrameLayout,ViewAnimator類(lèi)的作用是為FrameLayout里面的View切換提供動(dòng)畫(huà)效果。該類(lèi)有如下幾個(gè)和動(dòng)畫(huà)相關(guān)的函數(shù):
setInAnimation:設(shè)置View進(jìn)入屏幕時(shí)候使用的動(dòng)畫(huà),該函數(shù)有兩個(gè)版本,一個(gè)接受單個(gè)參數(shù),類(lèi)型為android.view.animation.Animation;一個(gè)接受兩個(gè)參數(shù),類(lèi)型為Context和int,分別為Context對(duì)象和定義Animation的resourceID。
setOutAnimation: 設(shè)置View退出屏幕時(shí)候使用的動(dòng)畫(huà),參數(shù)setInAnimation函數(shù)一樣。
showNext: 調(diào)用該函數(shù)來(lái)顯示FrameLayout里面的下一個(gè)View。
showPrevious: 調(diào)用該函數(shù)來(lái)顯示FrameLayout里面的上一個(gè)View。
一般不直接使用ViewAnimator而是使用它的兩個(gè)子類(lèi)ViewFlipper和ViewSwitcher。ViewFlipper可以用來(lái)指定FrameLayout內(nèi)多個(gè)View之間的切換效果,可以一次指定也可以每次切換的時(shí)候都指定單獨(dú)的效果。該類(lèi)額外提供了如下幾個(gè)函數(shù):
isFlipping: 用來(lái)判斷View切換是否正在進(jìn)行
setFilpInterval:設(shè)置View之間切換的時(shí)間間隔
startFlipping:使用上面設(shè)置的時(shí)間間隔來(lái)開(kāi)始切換所有的View,切換會(huì)循環(huán)進(jìn)行
stopFlipping: 停止View切換
ViewFilpper的使用方法:
配置頁(yè)面文件
<ViewFlipper android:id="@+id/flipper"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_below="@+id/CockpitLayout" >
<include android:id="@+id/secondlayout" layout="@layout/second" > </include>
<include android:id="@+id/firstlayout" layout="@layout/first" > </include>
</ViewFlipper>
可以動(dòng)態(tài)添加頁(yè)面
flipper.addView(View(), new LayoutParams(LayoutParams.FILL_PARENT,LayoutParams.FILL_PARENT));
配置好頁(yè)面文件后便可在代碼中對(duì)ViewFilpper進(jìn)行操作和設(shè)置切換動(dòng)畫(huà)
android-viewflow 是 Android 平臺(tái)上一個(gè)視圖切換的效果庫(kù)。
ViewFlow 相當(dāng)于 Android UI 部件提供水平滾動(dòng)的 ViewGroup,使用 Adapter 進(jìn)行條目綁定。文檔上說(shuō),當(dāng)你需要在一系列不確定數(shù)目的view中滑動(dòng)時(shí),可以考慮使用ViewFlow。如果你的view數(shù)目確定,你應(yīng)該使用Fragments 或兼容庫(kù)里的ViewPager 。
1、使用ViewFlow
怎么使用呢?首先在你的layout文件中加入:
<org.taptwo.android.widget.ViewFlow
android:id=”@+id/viewflow”
app:sidebuffer=”5″
/>
其中app:sidebuffer屬性是ViewFlow組件自定義的,使用這些屬性時(shí),需要增加如下的xml的命名空間:
xmlns:app=”http://schemas.android.com/apk/res/your.application.package.here”
然后在你的Activity里面添加如下代碼用于使用ViewFlow:
ViewFlow viewFlow =
(ViewFlow) findViewById(R.id.viewflow);
viewFlow.setAdapter(myAdapter);
//
設(shè)置初始view的位置
//
viewFlow.setAdapter(myAdapter, 8);
//
監(jiān)聽(tīng)view切換事件,簡(jiǎn)單的需求可不監(jiān)聽(tīng)
viewFlow.setOnViewSwitchListener(
new
ViewSwitchListener() {
public
void
onSwitched(View v,
int
position) {
/ /
Your code here
}
});
當(dāng)然,你也可以使用該庫(kù)中的FlowIndicator為你在多個(gè)view中切換時(shí)提供一個(gè)指示器,目前該庫(kù)已經(jīng)實(shí)現(xiàn)了兩種指示器:一種是圓點(diǎn)指示器FlowIndicator;另一種是標(biāo)題指示器TitleFlowIndicator。
1、使用圓點(diǎn)指示器
圓點(diǎn)指示器可以這樣使用:
先在layout中這樣定義
<org.taptwo.android.widget.CircleFlowIndicator
android:padding="10dip"
android:layout_height="wrap_content"
android:layout_width="wrap_content"
android:id="@+id/viewflowindic"
android:background="#00000000"
/>
然后在你的Activity里面添加如下代碼用于使用ViewFlow:
ViewFlow viewFlow = (ViewFlow) findViewById(R.id.viewflow);
viewFlow.setAdapter(myAdapter);
//設(shè)置初始view的位置
//viewFlow.setAdapter(myAdapter, 8);
//監(jiān)聽(tīng)view切換事件,簡(jiǎn)單的需求可不監(jiān)聽(tīng)
viewFlow.setOnViewSwitchListener(new ViewSwitchListener() {
public void onSwitched(View v, int position) {
/ / Your code here
}
});
圓點(diǎn)指示器還支持activeColor、inactiveColor、activeType(填充或描邊)、inactiveType(填充或描邊)、fadeOut(設(shè)置圓點(diǎn)自動(dòng)隱藏的秒數(shù),若為0則不會(huì)自動(dòng)隱藏)、radius(圓點(diǎn)的半徑)等。
2、使用標(biāo)題指示器
標(biāo)題指示器也是先layout里定義:
<org.taptwo.android.widget.TitleFlowIndicator
android:id="@+id/viewflowindic"
android:layout_height="wrap_content"
android:layout_width="fill_parent"
app:footerLineHeight="2dp"
app:footerTriangleHeight="10dp"
app:textColor="#FFFFFFFF"
app:selectedColor="#FFFFC445"
app:footerColor="#FFFFC445"
app:titlePadding="10dp"
app:textSize="11dp"
app:selectedSize="12dp"
android:layout_marginTop="10dip"
app:clipPadding="5dp" />
然后在activity中調(diào)用它:
TitleFlowIndicator indicator = (TitleFlowIndicator)
findViewById(R.id.viewflowindic);
indicator.setTitleProvider(myTitleProvider);
viewFlow.setFlowIndicator(indicator);
以上就是ViewFlow庫(kù)提供三大組件及其用法(來(lái)自其文檔),使用時(shí)需要下載到其代碼并放在你的項(xiàng)目中的某個(gè)包內(nèi),當(dāng)然你也可以把該組件庫(kù)打包成jar調(diào)用。
根據(jù)以上對(duì)三種實(shí)現(xiàn)的使用描述,可以看出,ViewPager與ViewFlow都能夠使用適配器進(jìn)行大量數(shù)據(jù)的適配。并且ViewFlow也帶有原點(diǎn)和標(biāo)題的位置提示,二者比較相像。ViewFilpper使用時(shí)主要是在有限的少數(shù)頁(yè)面切換中比較合適,并且能夠自定義每一個(gè)切換動(dòng)畫(huà),用于一個(gè)應(yīng)用
聯(lián)系客服