![【移動(dòng)應(yīng)用開(kāi)發(fā)技術(shù)】怎么在Android中實(shí)現(xiàn)一個(gè)首頁(yè)無(wú)限輪播功能_第1頁(yè)](http://file4.renrendoc.com/view/f0435aedea644f27071806aef80bf2c8/f0435aedea644f27071806aef80bf2c81.gif)
![【移動(dòng)應(yīng)用開(kāi)發(fā)技術(shù)】怎么在Android中實(shí)現(xiàn)一個(gè)首頁(yè)無(wú)限輪播功能_第2頁(yè)](http://file4.renrendoc.com/view/f0435aedea644f27071806aef80bf2c8/f0435aedea644f27071806aef80bf2c82.gif)
![【移動(dòng)應(yīng)用開(kāi)發(fā)技術(shù)】怎么在Android中實(shí)現(xiàn)一個(gè)首頁(yè)無(wú)限輪播功能_第3頁(yè)](http://file4.renrendoc.com/view/f0435aedea644f27071806aef80bf2c8/f0435aedea644f27071806aef80bf2c83.gif)
![【移動(dòng)應(yīng)用開(kāi)發(fā)技術(shù)】怎么在Android中實(shí)現(xiàn)一個(gè)首頁(yè)無(wú)限輪播功能_第4頁(yè)](http://file4.renrendoc.com/view/f0435aedea644f27071806aef80bf2c8/f0435aedea644f27071806aef80bf2c84.gif)
![【移動(dòng)應(yīng)用開(kāi)發(fā)技術(shù)】怎么在Android中實(shí)現(xiàn)一個(gè)首頁(yè)無(wú)限輪播功能_第5頁(yè)](http://file4.renrendoc.com/view/f0435aedea644f27071806aef80bf2c8/f0435aedea644f27071806aef80bf2c85.gif)
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
【移動(dòng)應(yīng)用開(kāi)發(fā)技術(shù)】怎么在Android中實(shí)現(xiàn)一個(gè)首頁(yè)無(wú)限輪播功能
這期內(nèi)容當(dāng)中在下將會(huì)給大家?guī)?lái)有關(guān)怎么在Android中實(shí)現(xiàn)一個(gè)首頁(yè)無(wú)限輪播功能,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。多張輪播圖定時(shí)效果指示點(diǎn)以及每張圖片的文字說(shuō)明實(shí)現(xiàn)無(wú)限輪播,可滑動(dòng),圖片點(diǎn)擊事件開(kāi)始布局:<RelativeLayout
xmlns:android="/apk/res/android"
xmlns:tools="/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.yangziling.carousel.MainActivity">
<!--輪播圖-->
<FrameLayout
android:layout_width="match_parent"
android:layout_height="200dp">
<android.support.v4.view.ViewPager
android:id="@+id/vp"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
<!--指示點(diǎn)和圖片標(biāo)題-->
<LinearLayout
android:layout_width="match_parent"
android:layout_height="35dip"
android:layout_gravity="bottom"
android:background="#33000000"
android:gravity="center"
android:orientation="vertical">
<!--圖片配文-->
<TextView
android:id="@+id/title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="圖片標(biāo)題"
android:textColor="@android:color/white"
/>
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="3dip"
android:orientation="horizontal"
>
<!--指示點(diǎn)-->
<View
android:id="@+id/dot_0"
android:background="@drawable/dot_focused"/>
<View
android:id="@+id/dot_1"
android:background="@drawable/dot_normal"/>
<View
android:id="@+id/dot_2"
android:background="@drawable/dot_normal"/>
<View
android:id="@+id/dot_3"
android:background="@drawable/dot_normal"/>
<View
android:id="@+id/dot_4"
android:background="@drawable/dot_normal"/>
</LinearLayout>
</LinearLayout>
</FrameLayout>
</RelativeLayout>布局中抽取的view屬性:<style
name="view_attr">
<item
name="android:layout_width">5dp</item>
<item
name="android:layout_height">5dp</item>
<item
name="android:layout_marginLeft">5dp</item>
<item
name="android:layout_marginRight">5dp</item>
</style>這里我展示的一些圖片是在本地的,通過(guò)網(wǎng)絡(luò)框架加載圖片原理也是一樣的。這里直接給大家貼出來(lái)核心代碼:public
class
MainActivity
extends
AppCompatActivity
{
private
ViewPager
mMyViewPaper;
private
List<ImageView>
images;
private
List<View>
dots;
private
int
currentItem;
private
TextView
title;
private
MyAdapter
adapter;
//當(dāng)前顯示圖片的位置
private
int
localPosition
=
0;
//圖片的id
private
int[]
imageIds
=
new
int[]{R.drawable.a,
R.drawable.b,
R.drawable.c,
R.drawable.d,
R.drawable.e};
//圖片的標(biāo)題
private
String[]
titles
=
new
String[]{"藍(lán)天白云",
"青山綠水",
"枯藤老樹(shù)",
"人間仙境",
"島嶼大樹(shù)"};
private
TimerTask
mTimerTask;
//創(chuàng)建一個(gè)定時(shí)器
private
final
Timer
timer
=
new
Timer();
private
ImageView
mImageView;
@Override
protected
void
onCreate(Bundle
savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mMyViewPaper
=
(ViewPager)
findViewById(R.id.vp);
//顯示的圖片
images
=
new
ArrayList<>();
for
(int
i
=
0;
i
<
imageIds.length;
i++)
{
mImageView
=
new
ImageView(this);
mImageView.setBackgroundResource(imageIds[i]);
images.add(mImageView);
}
//指示點(diǎn)
dots
=
new
ArrayList<>();
dots.add(findViewById(R.id.dot_0));
dots.add(findViewById(R.id.dot_1));
dots.add(findViewById(R.id.dot_2));
dots.add(findViewById(R.id.dot_3));
dots.add(findViewById(R.id.dot_4));
title
=
(TextView)
findViewById(R.id.title);
title.setText(titles[0]);
adapter
=
new
MyAdapter(MainActivity.this,
images);
mMyViewPaper.setAdapter(adapter);
mMyViewPaper.setOnPageChangeListener(new
ViewPager.OnPageChangeListener()
{
@Override
public
void
onPageSelected(int
position)
{
position
=
position
%
images.size();
title.setText(titles[position]);
dots.get(position).setBackgroundResource(R.drawable.dot_focused);
dots.get(localPosition).setBackgroundResource(R.drawable.dot_normal);
localPosition
=
position;
currentItem
=
position;
}
/**
*
頁(yè)面滑動(dòng)時(shí)回調(diào)
*/
@Override
public
void
onPageScrolled(int
arg0,
float
arg1,
int
arg2)
{
}
/**
*
當(dāng)ViewPager狀態(tài)改變時(shí),回調(diào)
*/
@Override
public
void
onPageScrollStateChanged(int
state)
{
}
});
}
/**
*
輪播任務(wù)
*/
@Override
protected
void
onStart()
{
super.onStart();
mTimerTask
=
new
TimerTask()
{
@Override
public
void
run()
{
currentItem
=
(currentItem
+
1)
%
imageIds.length;
mHandler.sendEmptyMessage(0);
}
};
timer.schedule(mTimerTask,
2000,
2000);
}
/**
*
接收子線程傳遞的數(shù)據(jù)
*/
private
Handler
mHandler
=
new
Handler()
{
public
void
handleMessage(android.os.Message
msg)
{
//輪播到最后一張圖片時(shí),直接跳轉(zhuǎn)至第一頁(yè),并且取消滑動(dòng)效果
if
(currentItem
%
images.size()
==
0)
{
mMyViewPaper.setCurrentItem(currentItem,
false);
}
//非最后一張展示圖片的滑動(dòng)效果
mMyViewPaper.setCurrentItem(currentItem,
true);
}
};
@Override
protected
void
onStop()
{
super.onStop();
timer.cancel();
}
}自定義了一個(gè)Adapter適配器:public
class
MyAdapter
extends
PagerAdapter
{
private
List<ImageView>
images;
private
Context
mContext;
public
MyAdapter(Context
context,List<ImageView>
images)
{
this.mContext
=context;
this.images
=
images;
}
//返回Viewpager中的view個(gè)數(shù)
@Override
public
int
getCount()
{
return
Integer.MAX_VALUE;
}
//判斷instantiateItem中的函數(shù)返回的key與一個(gè)頁(yè)面示圖是不是代表同一個(gè)
//通常直接相等就OK啦
@Override
public
boolean
isViewFromObject(View
arg0,
Object
arg1)
{
return
arg0
==
arg1;
}
//移除一個(gè)固定位置的頁(yè)面
@Override
public
void
destroyItem(ViewGroup
view,
int
position,
Object
object)
{
view.removeView((View)
object);
}
//將固定位置的View添加到Viewgroup中,并創(chuàng)建顯示出來(lái)
@Override
public
Object
instantiateItem(ViewGroup
view,
final
int
position)
{
ImageView
imageView
=
images.get(position
%
images.size());
ViewGroup
parent
=
(ViewGroup)
imageView.getParent();
//這里是動(dòng)態(tài)添加示圖,一個(gè)子類只能有一個(gè)父類
//判斷下如果parent存在一定要記得移除
if
(parent
!=
null)
{
parent.removeView(imageView);
}
view.addView(imageView);
//給圖片添加點(diǎn)擊事件
imageView.setOnClickListener(new
View.OnClickListener(){
@Override
public
void
onClick(View
v
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年巴音郭楞道路運(yùn)輸從業(yè)資格證考試內(nèi)容是什么
- 小學(xué)三年級(jí)100道口算題
- 2025年欽州貨運(yùn)上崗證模擬考試題
- 2025年荷澤貨運(yùn)從業(yè)資格證模擬考試駕考
- 華東師大版七年級(jí)數(shù)學(xué)上冊(cè)《第3章整式的加減3.1列代數(shù)式3.1.3列代數(shù)式 》聽(tīng)評(píng)課記錄
- 湘教版數(shù)學(xué)八年級(jí)下冊(cè)《2.2.1平行四邊形的邊、角性質(zhì)》聽(tīng)評(píng)課記錄
- 建筑項(xiàng)目經(jīng)理工作總結(jié)
- 初中理科教研組工作計(jì)劃
- 新學(xué)校校辦室工作計(jì)劃
- 平面設(shè)計(jì)師工作計(jì)劃范文欣賞
- 《反家庭暴力》課件
- 【物理】《跨學(xué)科實(shí)踐:制作簡(jiǎn)易桿秤》(教學(xué)設(shè)計(jì))-2024-2025學(xué)年人教版(2024)初中物理八年級(jí)下冊(cè)
- 新蘇教版一年級(jí)數(shù)學(xué)下冊(cè)第六單元《簡(jiǎn)單的數(shù)量關(guān)系(一)》教案(共2課時(shí))
- GA/T 2146-2024法庭科學(xué)涉火案件物證檢驗(yàn)移動(dòng)實(shí)驗(yàn)室建設(shè)通用要求
- 2024-2025學(xué)年成都市石室聯(lián)中七年級(jí)上英語(yǔ)期末考試題(含答案)
- 2025年度服務(wù)外包合同:銀行呼叫中心服務(wù)外包協(xié)議3篇
- 【課件】跨學(xué)科實(shí)踐制作微型密度計(jì)++課件人教版物理八年級(jí)下冊(cè)
- 北師大版五年級(jí)數(shù)學(xué)下冊(cè)第4課時(shí)體積單位的換算課件
- Module 2 Unit 2 I dont like ginger. (說(shuō)課稿)-2024-2025學(xué)年外研版(一起)英語(yǔ)二年級(jí)上冊(cè)
- 2025年新高考語(yǔ)文模擬考試試卷(五) (含答案解析)
- 教育部《中小學(xué)校園食品安全和膳食經(jīng)費(fèi)管理工作指引》專題培訓(xùn)
評(píng)論
0/150
提交評(píng)論