Android實(shí)現(xiàn)輪播效果的兩種方法
實(shí)現(xiàn)輪播效果有2種方法:
(1)使用ViewPager+ImageView,通過Handler進(jìn)行間隔發(fā)送消息,實(shí)現(xiàn)自動輪播效果
xml代碼:
<android.support.v4.view.ViewPager
android:id="@+id/fragment_viewPager"
android:layout_width="match_parent"
android:layout_height="200dp" />
private Handler handler=new Handler(){
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
list= (List<BannerBean>) msg.obj;
//進(jìn)行下載圖片
for (int i = 0; i < 3; i++) {
Picasso.with(getActivity()).load(list.get(i).getImgs()).resize(640,400).into(imgs.get(i));
}
//展示圖片
MyAdapter adapter=new MyAdapter();
viewPager.setAdapter(adapter);
}
};
private Handler handler2=new Handler(){
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
//獲取當(dāng)前viewPager的位置
int pos=viewPager.getCurrentItem();
//如果是最后一張圖片就進(jìn)行設(shè)置為第一張,實(shí)現(xiàn)循環(huán)
if(pos==imgs.size()-1){
pos=0;
//否則進(jìn)行下一張圖片展示
}else{
pos++;
}
//設(shè)置viewPager的位置
viewPager.setCurrentItem(pos);
//定時(shí)發(fā)送消息
handler2.sendEmptyMessageDelayed(1,2000);
}
};
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View view=inflater.inflate(R.layout.fragment_recreation, container, false);
initview(view);
load();
//發(fā)送消息給handler2,實(shí)現(xiàn)自動輪播
handler2.sendEmptyMessageDelayed(1,2000);
initListener();
return view;
}
private void load() {
//下載圖片地址
new Thread(){
@Override
public void run() {
super.run();
String json= Utils.getJsonFromNet(ContentUrls.headLine_head+0);
if(!TextUtils.isEmpty(json)){
List<BannerBean>data= ParserBanner.getData(json);
Message msg=new Message();
msg.obj=data;
handler.sendMessage(msg);
}
}
}.start();
data=new ArrayList<>();
headlineAdapter=new HeadlineAdapter(data,getActivity());
lv.setAdapter(headlineAdapter);
new MyAsyncTask(data,headlineAdapter).execute(ContentUrls.headLine_head+num);
}
private void initview(View view) {
lv = ((ListView) view.findViewById(R.id.lv));
headerView = LayoutInflater.from(getActivity()).inflate(R.layout.header_layout,null,false);
viewPager = ((ViewPager)headerView.findViewById(R.id.fragment_viewPager));
lv.addHeaderView(headerView);
list=new ArrayList<>();
imgs=new ArrayList<>();
for (int i = 0; i < 3; i++) {
ImageView iv=new ImageView(getActivity());
imgs.add(iv);
}
}
adapter:
class MyAdapter extends PagerAdapter{
@Override
public int getCount() {
return imgs.size();
}
@Override
public boolean isViewFromObject(View view, Object object) {
return view==object;
}
@Override
public Object instantiateItem(ViewGroup container, int position) {
container.addView(imgs.get(position));
return imgs.get(position);
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
// super.destroyItem(container, position, object);
container.removeView(imgs.get(position));
}
}
(2)使用SliderLayout第三方進(jìn)行實(shí)現(xiàn)輪播
添加依賴:
compile 'com.squareup.picasso:picasso:2.5.2' compile 'com.daimajia.slider:library:1.1.5@aar' compile 'com.nineoldandroids:library:2.4.0'
xml代碼:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<com.daimajia.slider.library.SliderLayout
android:id="@+id/header_slider"
android:layout_width="match_parent"
android:layout_height="160dp"></com.daimajia.slider.library.SliderLayout>
</LinearLayout>
Java代碼:
private ListView lv;
private String[] title={"煙","超標(biāo)","標(biāo)準(zhǔn)","審車合格"};
private int[] imgs={R.mipmap.a,R.mipmap.b,R.mipmap.c,R.mipmap.d};
private SliderLayout slider;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View view=inflater.inflate(R.layout.fragment_home_page, container, false);
lv = ((ListView) view.findViewById(R.id.homePage_lv));
View headerView=LayoutInflater.from(getActivity()).inflate(R.layout.header_layout,null,false);
slider = ((SliderLayout) headerView.findViewById(R.id.header_slider));
lv.addHeaderView(headerView);
initSlider();
initData();
return view;
}
private void initSlider() {
for (int i = 0; i < 4; i++) {
TextSliderView textSlider=new TextSliderView(getActivity());
textSlider.image(imgs[i]).description(title[i]);
slider.addSlider(textSlider);
textSlider.setOnSliderClickListener(new BaseSliderView.OnSliderClickListener() {
@Override
public void onSliderClick(BaseSliderView slider) {
Toast.makeText(getActivity(),slider.getDescription(),Toast.LENGTH_SHORT).show();
}
});
}
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android實(shí)現(xiàn)圖片輪播效果的兩種方法
- Android實(shí)現(xiàn)圖片輪播效果
- Android 使用ViewPager自動滾動循環(huán)輪播效果
- Android實(shí)現(xiàn)Banner界面廣告圖片循環(huán)輪播(包括實(shí)現(xiàn)手動滑動循環(huán))
- Android實(shí)現(xiàn)圖片文字輪播特效
- Android實(shí)現(xiàn)廣告圖片輪播效果
- Android自定義控件實(shí)現(xiàn)簡單的輪播圖控件
- Android實(shí)現(xiàn)圖片輪播切換實(shí)例代碼
- Android自動播放Banner圖片輪播效果
- Android ViewPager實(shí)現(xiàn)圖片輪播效果
相關(guān)文章
android客戶端從服務(wù)器端獲取json數(shù)據(jù)并解析的實(shí)現(xiàn)代碼
今天總結(jié)一下android客戶端從服務(wù)器端獲取json數(shù)據(jù)的實(shí)現(xiàn)代碼,需要的朋友可以參考下2013-06-06
Kotlin中的handler如何避免內(nèi)存泄漏詳解
Handler,我們已經(jīng)相當(dāng)熟悉了,而且經(jīng)常用得不亦樂乎,但就是因?yàn)樘煜ち耍艜紶柋凰赐币坏叮鞑恢?,下面這篇文章主要給大家介紹了關(guān)于Kotlin中handler如何避免內(nèi)存泄漏的相關(guān)資料,需要的朋友可以參考下。2017-12-12
AndriodStudio利用ListView和數(shù)據(jù)庫實(shí)現(xiàn)簡單學(xué)生管理
這篇文章主要為大家詳細(xì)介紹了AndriodStudio利用ListView和數(shù)據(jù)庫實(shí)現(xiàn)簡單學(xué)生管理,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
Android Naive與WebView的互相調(diào)用詳解
這篇文章主要介紹了Android Naive與WebView的互相調(diào)用詳解的相關(guān)資料,需要的朋友可以參考下2017-05-05
WindowManagerService服務(wù)是如何以堆棧的形式來組織窗口
我們知道,在Android系統(tǒng)中,Activity是以堆棧的形式組織在ActivityManagerService服務(wù)中的;在本文中,我們就詳細(xì)分析WindowManagerService服務(wù)是如何以堆棧的形式來組織窗口的2013-01-01

