广告轮播图

/**
 * 广告图片自动轮播控件</br>
 * 
 */
public class ImageCycleView extends LinearLayout {
/**
* 上下文
*/
private Context mContext;
/**
* 图片轮播视图
*/
private ViewPager mAdvPager = null;
/**
* 滚动图片视图适配
*/
private ImageCycleAdapter mAdvAdapter;
/**
* 图片轮播指示器控件
*/
private ViewGroup mGroup;


/**
* 图片轮播指示个图
*/
private ImageView mImageView = null;


/**
* 滚动图片指示视图列表
*/
private ImageView[] mImageViews = null;


/**
* 图片滚动当前图片下标
*/
// private int mImageIndex = 0;


/**
* 手机密度
*/
private float mScale;
private boolean isStop;
// private TextView[] mTextViews;
// private TextView mTextView;
// private ViewGroup mGroup2;
// ArrayList<String> imageNameList;
// private TextView imageName;
/**
* @param context
*/
public ImageCycleView(Context context) {
super(context);
}
/**
* @param context
* @param attrs
*/
public ImageCycleView(Context context, AttributeSet attrs) {
super(context, attrs);
mContext = context;
mScale = context.getResources().getDisplayMetrics().density;
LayoutInflater.from(context).inflate(R.layout.ad_cycle_view, this);
mAdvPager = (ViewPager) findViewById(R.id.adv_pager);
mAdvPager.setOnPageChangeListener(new GuidePageChangeListener());
mAdvPager.setOnTouchListener(new OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
switch (event.getAction()) {
case MotionEvent.ACTION_UP:
// 开始图片滚动
if(null!=mImageViews){
if(mImageViews.length!=1){
startImageTimerTask();
}
}
break;
default:
// 停止图片滚动
if(null!=mImageViews){
if(mImageViews.length!=1){
stopImageTimerTask();
}
}
break;
}
return false;
}
});
// 滚动图片右下指示器视
mGroup = (ViewGroup) findViewById(R.id.viewGroup);
// imageName = (TextView) findViewById(R.id.viewGroup2);
}
/**
* 装填图片数据

* @param imageUrlList
* @param imageCycleViewListener
*/
public void setImageResources(ArrayList<AmoyBeautyMainTopImg> headList_,ImageCycleViewListener imageCycleViewListener) {
// this.imageNameList=imageNameList;
// 清除
mGroup.removeAllViews();
// 图片广告数量
mImageViews = new ImageView[headList_.size()];
if(null!=headList_&&headList_.size()==1){
mAdvAdapter = new ImageCycleAdapter(mContext, headList_,imageCycleViewListener);
mAdvPager.setAdapter(mAdvAdapter);
}else{
if(null!=headList_&&headList_.size()!=0){
for (int i = 0; i < headList_.size(); i++) {
mImageView = new ImageView(mContext);
int imageParams = (int) (mScale * 10 + 0.5f);// XP与DP转换,适应应不同分辨率
int imagePadding = (int) (mScale * 5 + 0.5f);
LayoutParams params=new LayoutParams(imageParams,imageParams);
params.leftMargin=10; 
mImageView.setScaleType(ScaleType.CENTER_CROP);
mImageView.setLayoutParams(params);
mImageView.setPadding(imagePadding, imagePadding, imagePadding, imagePadding);


mImageViews[i] = mImageView;
if (i == 0) {
mImageViews[i].setBackgroundResource(R.drawable.viewpage_shixin);
} else {
mImageViews[i].setBackgroundResource(R.drawable.viewpage_kongxin);
}
mGroup.addView(mImageViews[i]);
}
}
// imageName.setText(imageNameList.get(0));
mAdvAdapter = new ImageCycleAdapter(mContext, headList_,imageCycleViewListener);
mAdvPager.setAdapter(mAdvAdapter);
startImageTimerTask();
}


}


/**
* 图片轮播(手动控制自动轮播与否,便于资源控件)
*/
public void startImageCycle() {
startImageTimerTask();
}


/**
* 暂停轮播—用于节省资源
*/
public void pushImageCycle() {
stopImageTimerTask();
}


/**
* 图片滚动任务
*/
private void startImageTimerTask() {
stopImageTimerTask();
// 图片滚动
mHandler.postDelayed(mImageTimerTask, 4000);
}


/**
* 停止图片滚动任务
*/
private void stopImageTimerTask() {
isStop=true;
mHandler.removeCallbacks(mImageTimerTask);
}


private Handler mHandler = new Handler();


/**
* 图片自动轮播Task
*/
private Runnable mImageTimerTask = new Runnable() {
@Override
public void run() {
if (mImageViews != null) {
mAdvPager.setCurrentItem(mAdvPager.getCurrentItem()+1);
if(!isStop){  //if  isStop=true   //当你退出后 要把这个给停下来 不然 这个一直存在 就一直在后台循环 
mHandler.postDelayed(mImageTimerTask, 4000);
}


}
}
};


/**
* 轮播图片监听

* @author minking
*/
private final class GuidePageChangeListener implements OnPageChangeListener {
@Override
public void onPageScrollStateChanged(int state) {
if(null!=mImageViews&&mImageViews.length!=1){
if (state == ViewPager.SCROLL_STATE_IDLE)
startImageTimerTask(); 
}
}
@Override
public void onPageScrolled(int arg0, float arg1, int arg2) {
}
@Override
public void onPageSelected(int index) {
if(null!=mImageViews&&mImageViews.length!=1){
index=index%mImageViews.length;
// 设置当前显示的图片
// mImageIndex = index;
// 设置图片滚动指示器背
mImageViews[index].setBackgroundResource(R.drawable.viewpage_shixin);
// imageName.setText(imageNameList.get(index));
for (int i = 0; i < mImageViews.length; i++) {
if (index != i) {
mImageViews[i].setBackgroundResource(R.drawable.viewpage_kongxin);
}
}
}
}
}


private class ImageCycleAdapter extends PagerAdapter {


/**
* 图片视图缓存列表
*/
private ArrayList<ImageView> mImageViewCacheList;


/**
* 图片资源列表
*/
private ArrayList<AmoyBeautyMainTopImg> mAdList= new ArrayList<AmoyBeautyMainTopImg>();
// private ArrayList<String> nameList = new ArrayList<String>();


/**
* 广告图片点击监听
*/
private ImageCycleViewListener mImageCycleViewListener;


private Context mContext;
public ImageCycleAdapter(Context context,ArrayList<AmoyBeautyMainTopImg> headList_, ImageCycleViewListener imageCycleViewListener) {
this.mContext = context;
this.mAdList = headList_;
// this.nameList = nameList;
mImageCycleViewListener = imageCycleViewListener;
mImageViewCacheList = new ArrayList<ImageView>();
}


@Override
public int getCount() {
// return mAdList.size();
return Integer.MAX_VALUE;
}
@Override
public boolean isViewFromObject(View view, Object obj) {
return view == obj;
}


@Override
public Object instantiateItem(ViewGroup container, final int position) {
String imageUrl = mAdList.get(position%mAdList.size()).getIMAGEURL();
ImageView imageView = null;
if (mImageViewCacheList.isEmpty()) {
imageView = new ImageView(mContext);
imageView.setLayoutParams(new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);




} else {
imageView = mImageViewCacheList.remove(0);
}
// 设置图片点击监听
imageView.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
mImageCycleViewListener.onImageClick(position%mAdList.size(), v);
}
});
imageView.setTag(imageUrl);
container.addView(imageView);
mImageCycleViewListener.displayImage(imageUrl, imageView);
return imageView;
}


@Override
public void destroyItem(ViewGroup container, int position, Object object) {
ImageView view = (ImageView) object;
mAdvPager.removeView(view);
mImageViewCacheList.add(view);


}


}


/**
* 轮播控件的监听事件

* @author minking
*/
public static interface ImageCycleViewListener {
/**
* 加载图片资源

* @param imageURL
* @param imageView
*/
public void displayImage(String imageURL, ImageView imageView);


/**
* 单击图片事件

* @param position
* @param imageView
*/
public void onImageClick(int position, View imageView);
}


}






<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/ad_rl"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >


    <android.support.v4.view.ViewPager
        android:id="@+id/adv_pager"
        android:layout_width="match_parent"
        android:layout_height="match_parent" >
    </android.support.v4.view.ViewPager>


    <LinearLayout
        android:id="@+id/viewGroup"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:layout_marginBottom="8dp"
        android:gravity="center"
        android:orientation="horizontal" >
    </LinearLayout>


<!--     <TextView -->
<!--         android:id="@+id/viewGroup2" -->
<!--         android:layout_width="match_parent" -->
<!--         android:layout_height="wrap_content" -->
<!--         android:gravity="center" -->
<!--         android:textColor="@color/white" -->
<!--         android:padding="15dp" -->
<!--         android:background="@color/dingbu_ban_touming" -->
<!--         android:layout_above="@+id/viewGroup" -->
<!--         android:layout_alignParentLeft="true" -->
<!--         android:layout_alignParentRight="true" -->
<!--         android:layout_marginBottom="25dp" -->
<!--         android:orientation="horizontal" > -->
<!--     </TextView> -->


</RelativeLayout>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值