Android Viewpager實現(xiàn)輪播廣告圖
更新時間:2018年05月23日 09:16:37 作者:qiaoyihebg
這篇文章主要為大家詳細介紹了Android Viewpager實現(xiàn)輪播廣告圖,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了Android Viewpager輪播廣告圖的具體代碼,供大家參考,具體內(nèi)容如下
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="${relativePackage}.${activityClass}" >
<android.support.v4.view.ViewPager
android:id="@+id/viewpager_main"
android:layout_width="match_parent"
android:layout_height="180dp"
></android.support.v4.view.ViewPager>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:layout_alignBottom="@id/viewpager_main"
android:background="#44000000"
>
<TextView
android:id="@+id/text_main_tatle"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="3dp"
android:gravity="center_horizontal"
android:text="廣告標題"
android:textColor="#fff"
/>
<LinearLayout
android:id="@+id/ll_main_point_group"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:layout_gravity="center_horizontal"
></LinearLayout>
</LinearLayout>
</RelativeLayout>
主代碼寫
package com.example.viewpager_text2;
import java.util.ArrayList;
import android.R.integer;
import android.annotation.SuppressLint;
import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.view.Menu;
import android.view.MenuItem;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.View.OnTouchListener;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;
import android.widget.Toast;
public class MainActivity extends Activity {
ViewPager viewPager;
TextView text_main_tatle;
LinearLayout ll_main_point_group;
ArrayList <ImageView>imageviews;
//圖片資源
int [] imageids={
R.drawable.a,
R.drawable.b,
R.drawable.c,
R.drawable.d,
R.drawable.e,
};
//圖片的標題集合
String [] imagetion={
"有型有范","周末放假","家電買一送一","預約迎新機","京東火鍋節(jié)"
};
int preposition=0;//設(shè)置高亮的位置
Handler handler=new Handler(){
public void handleMessage(android.os.Message msg) {
int item=viewPager.getCurrentItem()+1;
viewPager.setCurrentItem(item);
//延遲發(fā)消息
handler.sendEmptyMessageDelayed(0,3000);
};
};
boolean isdragging=false;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//加載布局初始化
viewPager=(ViewPager) findViewById(R.id.viewpager_main);
text_main_tatle=(TextView) findViewById(R.id.text_main_tatle);
ll_main_point_group=(LinearLayout) findViewById(R.id.ll_main_point_group);
// listview 的使用
// 1,在布局中文件定義viewpager
// 2,在代碼中實例化Viewpager
// 3,準備數(shù)據(jù)
imageviews=new ArrayList<ImageView>();
for(int i=0;i<imageids.length;i++){
ImageView imageview=new ImageView(this);
imageview.setBackgroundResource(imageids[i]);
//添加到集合中
imageviews.add(imageview);
//添加小圓點
ImageView imageview1=new ImageView(this);
imageview1.setBackgroundResource(R.drawable.xuna);
LinearLayout.LayoutParams par=new LinearLayout.LayoutParams(8,8);
if(i==0){
imageview1.setEnabled(true);//顯示紅色
}else{
imageview1.setEnabled(false);//顯示灰色
par.leftMargin=8;
}
ll_main_point_group.addView(imageview1);
}
// 4,設(shè)置適配器(pageradapter)-Item布局-綁定數(shù)據(jù)
viewPager.setAdapter(new Mypager());
viewPager.setOnPageChangeListener(new myon());
//設(shè)置中間位置,要保證是imageview的整數(shù)倍數(shù)
int item=Integer.MAX_VALUE/2-
Integer.MAX_VALUE/2 % imageviews.size();
viewPager.setCurrentItem(item);
text_main_tatle.setText(imagetion[preposition]);
//延遲發(fā)消息
handler.sendEmptyMessageDelayed(0,3000);
}
class myon implements OnPageChangeListener {
//當前頁面滾動變化的時候會回調(diào)此方法
// 靜止-->滑動 或 滑動-->靜止 或 靜止-->拖拽
@Override
public void onPageScrollStateChanged(int arg0) {
// TODO Auto-generated method stub
if(arg0==ViewPager.SCROLL_STATE_DRAGGING){//拖拽
isdragging=true;
}else if(arg0==ViewPager.SCROLL_STATE_SETTLING){//滾動
}else if(arg0==ViewPager.SCROLL_STATE_IDLE&& isdragging){//靜止
isdragging=false;
handler.removeCallbacksAndMessages(null);
handler.sendEmptyMessageDelayed(0, 3000);
}
}
// 當前頁面滾動的時候回調(diào)此方法
// arg0 當期頁面的位置
// arg1滑動頁面的百分比
// arg2 在屏幕上滑動的像素
@Override
public void onPageScrolled(int arg0, float arg1, int arg2) {
// TODO Auto-generated method stub
}
//當某個界面被選中時的回調(diào)方法
// arg0本選中頁面的位置
@Override
public void onPageSelected(int arg0) {
// TODO Auto-generated method stub
int realpostion=arg0%imageviews.size();
//設(shè)置對應(yīng)頁面的文本信息
text_main_tatle.setText(imagetion[realpostion]);
//壩上一個高亮的設(shè)置成灰色
ll_main_point_group.getChildAt(preposition)
.setEnabled(false);
//當前設(shè)置成紅色
ll_main_point_group.getChildAt(realpostion)
.setEnabled(true);
preposition=realpostion;
}
}
class Mypager extends PagerAdapter{
//得到圖片的總數(shù)
@Override
public int getCount() {
// TODO Auto-generated method stub
// return imageviews.size();
return Integer.MAX_VALUE;//int類型的最大值
}
//相當于getView的方法
//container Viewpager自身
//position 當前實例化頁面的位置(下標)
@Override
public Object instantiateItem(ViewGroup container, int position) {
int realPostion=position% imageviews.size();
// TODO Auto-generated method stub
ImageView imageview = imageviews.get(realPostion);
container.addView(imageview);//添加到Viewpager中
imageview.setOnTouchListener(new OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
// TODO Auto-generated method stub
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN://手指按下時的操作
handler.removeCallbacksAndMessages(null);
break;
case MotionEvent.ACTION_MOVE://手指移動時的操作
break;
case MotionEvent.ACTION_CANCEL://事件取消
handler.removeCallbacksAndMessages(null);
handler.sendEmptyMessageDelayed(0, 3000);
break;
case MotionEvent.ACTION_UP://手指抬起時的操作
handler.removeCallbacksAndMessages(null);
handler.sendEmptyMessageDelayed(0, 3000);
break;
}
return false;
}
});
imageview.setTag(realPostion);
imageview.setOnClickListener(new OnClickListener() {
@SuppressLint("ShowToast")
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
int position = (Integer) v.getTag();
String text=imagetion[position];
Toast.makeText(MainActivity.this, text, 0).show();
}
});
return imageview;
}
//比較View和Object是否是同一個實例
//arg0 就是頁面
//arg1是instantiateItem返回的結(jié)果
@Override
public boolean isViewFromObject(View arg0, Object arg1) {
// TODO Auto-generated method stub
return arg0==arg1;
}
//釋放資源
// container就是Viewpager
// position 要釋放的位置
// object要釋放的頁面
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView((View) object);
}
}
}
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android中實現(xiàn)監(jiān)聽ScrollView滑動事件
這篇文章主要介紹了Android中實現(xiàn)監(jiān)聽ScrollView滑動事件,本文用重寫ScrollView類的方法實現(xiàn)了一些擴展功能,需要的朋友可以參考下2015-05-05
Android實現(xiàn)網(wǎng)絡(luò)加載時的對話框功能
這篇文章主要介紹了Android實現(xiàn)網(wǎng)絡(luò)加載時的對話框功能,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-02-02
Android?RxJava與Retrofit結(jié)合使用詳解
RxJava和Retrofit的結(jié)合使用估計已經(jīng)相當普遍了,自己工作中也是一直都在使用。在使用的過程中我們都會對其進行封裝使用,GitHub上也有很多封裝好的項目可以直接拿來使用,其實對于開源框架的二次封裝有時候針對不同的業(yè)務(wù)邏輯封裝的過程中也多多少少有些不同2023-03-03
Flutter定時器、倒計時的快速上手及實戰(zhàn)講解
這篇文章主要給大家介紹了關(guān)于Flutter定時器、倒計時的快速上手及實戰(zhàn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Flutter具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧2019-06-06
Android 對手機網(wǎng)絡(luò)的檢測和監(jiān)聽的方法示例
本篇文章主要介紹了Android 對手機網(wǎng)絡(luò)的檢測和監(jiān)聽的方法示例,主要使用BroadcastReceiver廣播接收器來接收網(wǎng)絡(luò)狀態(tài),現(xiàn)在分享給大家,也給大家做個參考,有興趣的一起來了解一下2018-03-03

