Viewpager 自动左右无线滑动 手动滑动

<p>package com.example.demo;</p><p>import java.util.concurrent.atomic.AtomicInteger;
import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.LinearLayout;</p><p>public class MainActivity extends Activity implements OnPageChangeListener{
 public AtomicInteger what = new AtomicInteger(0);
 private ViewPager viewPager;
 private ImageView[] tips = null;
 private ViewGroup group = null;
 private ImageView[] imageViews = null;
 private static final int MSG_CHANGE_PHOTO = 1;
 private static final int PHOTO_CHANGE_TIME = 2000;
 public int imageSource[]={R.drawable.little_horse,R.drawable.p1,R.drawable.p2};
 
  @Override
     protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);
      initViewPager();
      viewPager.setAdapter(new MyAdapter());
   viewPager.setOnPageChangeListener(this);
   viewPager.setCurrentItem(imageViews.length*100);
   mHandler.sendEmptyMessageDelayed(MSG_CHANGE_PHOTO, PHOTO_CHANGE_TIME);
     }</p><p> 
     private Handler mHandler = new Handler() {
         @Override
         public void dispatchMessage(Message msg) {
             switch (msg.what) {
             case MSG_CHANGE_PHOTO:
                 int index = viewPager.getCurrentItem();
                 viewPager.setCurrentItem(index + 1);
                 mHandler.sendEmptyMessageDelayed(MSG_CHANGE_PHOTO,
                         PHOTO_CHANGE_TIME);
                 break;
             }
             super.dispatchMessage(msg);
         }
     };
 
 
 private void initViewPager(){
  
  viewPager = (ViewPager) findViewById(R.id.viewPager);
  group = (ViewGroup)findViewById(R.id.viewGroup);
  imageViews = new ImageView[imageSource.length];
  for(int i=0; i<imageSource.length ;i++)
  {
   ImageView imageView = new ImageView(this);
   imageView.setBackgroundResource(imageSource[i]);
   imageViews[i] = imageView;
  }
  tips = new ImageView[imageSource.length];
  for(int i=0; i<tips.length; i++){
   ImageView imageView = new ImageView(this);
   LinearLayout.LayoutParams lp = new LinearLayout.LayoutParams(12,12);
   lp.setMargins(10, 10, 30, 20);
      imageView.setLayoutParams(lp);
      tips[i] = imageView;
      if(i == 0){
       tips[i].setBackgroundResource(R.drawable.page_indicator_focused);
      }else{
       tips[i].setBackgroundResource(R.drawable.page_indicator_unfocused);
      }
      group.addView(imageView);
  }
 }
 
 public class MyAdapter extends PagerAdapter{
  @Override
  public boolean isViewFromObject(View arg0, Object arg1) {
   return arg0 == arg1;
  }
  @Override
  public int getCount() {
   return Integer.MAX_VALUE;
  }
  @Override
  public void destroyItem(View container, int position, Object object) {
//   ((ViewPager)container).removeView(imageViews[position % imageViews.length]);
  }
  @Override
  public Object instantiateItem(View container, int position) {
   try {</p><p>    ((ViewPager)container).addView(imageViews[position % imageViews.length],0);
   } catch (Exception e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }
   return imageViews[position % imageViews.length];
  }
 }
 </p><p> @Override
 public void onPageScrollStateChanged(int arg0) {
  // TODO Auto-generated method stub
  
 }</p><p>
 @Override
 public void onPageScrolled(int arg0, float arg1, int arg2) {
  // TODO Auto-generated method stub
 
 }</p><p> @Override
 public void onPageSelected(int arg0) {
  // TODO Auto-generated method stub
  setImageBackground(arg0 % (imageSource.length));
 }
 private void setImageBackground(int selectItems){
  for(int i=0; i<imageSource.length; i++){
   if(i == selectItems){
    tips[i].setBackgroundResource(R.drawable.page_indicator_focused);
   }else{
    tips[i].setBackgroundResource(R.drawable.page_indicator_unfocused);
   }
  }
 }</p><p>    </p><p>}
</p>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
协同过滤算法(Collaborative Filtering)是一种经典的推荐算法,其基本原理是“协同大家的反馈、评价和意见,一起对海量的信息进行过滤,从中筛选出用户可能感兴趣的信息”。它主要依赖于用户和物品之间的行为关系进行推荐。 协同过滤算法主要分为两类: 基于物品的协同过滤算法:给用户推荐与他之前喜欢的物品相似的物品。 基于用户的协同过滤算法:给用户推荐与他兴趣相似的用户喜欢的物品。 协同过滤算法的优点包括: 无需事先对商品或用户进行分类或标注,适用于各种类型的数据。 算法简单易懂,容易实现和部署。 推荐结果准确性较高,能够为用户提供个性化的推荐服务。 然而,协同过滤算法也存在一些缺点: 对数据量和数据质量要求较高,需要大量的历史数据和较高的数据质量。 容易受到“冷启动”问题的影响,即对新用户或新商品的推荐效果较差。 存在“同质化”问题,即推荐结果容易出现重复或相似的情况。 协同过滤算法在多个场景中有广泛的应用,如电商推荐系统、社交网络推荐和视频推荐系统等。在这些场景中,协同过滤算法可以根据用户的历史行为数据,推荐与用户兴趣相似的商品、用户或内容,从而提高用户的购买转化率、活跃度和社交体验。 未来,协同过滤算法的发展方向可能是结合其他推荐算法形成混合推荐系统,以充分发挥各算法的优势。
要实现ViewPager的自动滑动手动滑动加点击切换,可以按以下步骤进行操作: 1. 在layout文件中添加ViewPager控件: ``` <android.support.v4.view.ViewPager android:id="@+id/view_pager" android:layout_width="match_parent" android:layout_height="wrap_content"/> ``` 2. 在Activity或Fragment中初始化ViewPager并设置Adapter: ``` ViewPager viewPager = findViewById(R.id.view_pager); viewPager.setAdapter(new MyPagerAdapter(getSupportFragmentManager())); ``` 3. 实现自动滑动功能,可以使用Handler和Runnable来实现: ``` private Handler handler = new Handler(); private Runnable runnable = new Runnable() { @Override public void run() { int currentItem = viewPager.getCurrentItem(); int count = viewPager.getAdapter().getCount(); if (currentItem < count - 1) { viewPager.setCurrentItem(currentItem + 1); } else { viewPager.setCurrentItem(0); } handler.postDelayed(runnable, 3000); } }; // 在onResume()方法中启动自动滑动 @Override protected void onResume() { super.onResume(); handler.postDelayed(runnable, 3000); } // 在onPause()方法中停止自动滑动 @Override protected void onPause() { super.onPause(); handler.removeCallbacks(runnable); } ``` 4. 实现手动滑动和点击切换功能,可以在ViewPager的OnPageChangeListener中处理: ``` viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() { @Override public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {} @Override public void onPageSelected(int position) { // 处理页面切换事件 } @Override public void onPageScrollStateChanged(int state) { // 处理滑动状态变化事件 } }); ``` 在onPageSelected()方法中可以处理页面切换事件,比如更新页面指示器的状态。在onPageScrollStateChanged()方法中可以处理滑动状态变化事件,比如停止自动滑动或重新开始自动滑动。 以上就是实现ViewPager自动滑动手动滑动加点击切换的基本步骤,具体实现可以根据需求进行调整。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值