看开源框架:https://github.com/tianshaojie/AndroidFine,里面有如下效果,特记录学习下,以后项目中用也好能够立刻想起来。
 
如上面所示,是常见项目中的图片轮训和展示效果,技术主要涉及到viewpager+photoview,那下面主要讲解如何在android App中如何实现该效果:
  1. 导入photoview相关代码:
    
    2.   头部轮训和展示的代码:
    
第1个页面的实现:
首先看布局:
activity_photoview.xml文件
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="160dp"
android:background="@color/white" >
<com.soyoungboy.widget.loopviewpager.AutoLoopViewPager
android:id="@+id/pager"
android:layout_width="fill_parent"
android:layout_height="fill_parent" />
<com.soyoungboy.widget.viewpagerindicator.CirclePageIndicator
android:id="@+id/indicator"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_centerHorizontal="true"
android:layout_marginBottom="5dp"
android:padding="5dp" />
</RelativeLayout>
PhotoViewActivity.java文件
  1. public class PhotoViewActivity extends BaseFragmentActivity {
    private com.soyoungboy.widget.loopviewpager.AutoLoopViewPager pager;
    private int[] imageViewIds;
    private com.soyoungboy.widget.viewpagerindicator.CirclePageIndicator indicator;
    private List<String> imageList = new ArrayList<String>(Arrays.asList(
    "http://pic.nipic.com/2008-07-11/20087119630716_2.jpg",
    "http://pic.nipic.com/2008-07-11/20087119630716_2.jpg",
    "http://pic.nipic.com/2008-07-11/20087119630716_2.jpg"));
    @Override
    protected void onCreate(Bundle arg0) {
    super.onCreate(arg0);
    setContentView(R.layout.activity_photoview);
    initView();
    }
    @Override
    protected void initView() {
    pager = (com.soyoungboy.widget.loopviewpager.AutoLoopViewPager) findViewById(R.id.pager);
    indicator = (com.soyoungboy.widget.viewpagerindicator.CirclePageIndicator) findViewById(R.id.indicator);
    //设置要显示的图片内容
    imageViewIds = new int[] { R.drawable.house_background, R.drawable.house_background_1, R.drawable.house_background_2};
    //适配器
    GalleryPagerAdapter galleryAdapter = new GalleryPagerAdapter();
    pager.setAdapter(galleryAdapter);
    indicator.setViewPager(pager);
    //控制距离左边,上边,右边,下边的px距离
    indicator.setPadding(5, 5, 10, 5);
    }
    @Override
    protected void initTitleView() {
    }
    @Override
    protected void click(View view) {
    }
    //轮播图适配器
    public class GalleryPagerAdapter extends PagerAdapter {
    @Override
    public int getCount() {
    return imageViewIds.length;
    }
    @Override
    public boolean isViewFromObject(View view, Object object) {
    return view == object;
    }
    @Override
    public Object instantiateItem(ViewGroup container, int position) {
    ImageView item = new ImageView(PhotoViewActivity.this);
    //Imageview上面显示图片
    item.setImageResource(imageViewIds[position]);
    ViewGroup.LayoutParams params = new ViewGroup.LayoutParams(-1, -1);
    item.setLayoutParams(params);
    item.setScaleType(ImageView.ScaleType.FIT_XY);
    container.addView(item);
    final int pos = position;
    //Imageview单击事件处理
    item.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
    //进入ImageGalleryActivity代码里面去
    Intent intent = new Intent(PhotoViewActivity.this, ImageGalleryActivity.class);
    intent.putStringArrayListExtra("images", (ArrayList<String>) imageList);
    intent.putExtra("position", pos);
    startActivity(intent);
    }
    });
    return item;
    }
    @Override
    public void destroyItem(ViewGroup collection, int position, Object view) {
    collection.removeView((View) view);
    }
    }
    @Override
    protected void onResume() {
    super.onResume();
    //开始自动左右切换图片
    pager.startAutoScroll();
    }
    @Override
    protected void onPause() {
    super.onPause();
    //结束自动左右切换图片
    pager.stopAutoScroll();
    }
    }


第2张图功能实现:
首先布局文件activity_touch_gallery.xml

  1. <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:fitsSystemWindows="true"
    android:background="@color/black"> <android.support.v4.view.ViewPager
    android:id="@+id/viewer"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:layout_below="@+id/layoutHeader" /> </RelativeLayout>


ImageGalleryActivity .java
public class ImageGalleryActivity extends BaseFragmentActivity {

    private int position;
private List<String> imgUrls; //图片列表
private TextView headTitle;
private Button headBackBtn; private ViewPager mViewPager; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_touch_gallery); Intent intent = getIntent();
position = intent.getIntExtra("position", 0);
//获取图片的url List集合
imgUrls = intent.getStringArrayListExtra("images");
if(imgUrls == null) {
imgUrls = new ArrayList<>();
}
initGalleryViewPager();
} @Override
protected void onDestroy() {
super.onDestroy();
}
private void initGalleryViewPager() {
PhotoViewAdapter pagerAdapter = new PhotoViewAdapter(this, imgUrls);
pagerAdapter.setOnItemChangeListener(new PhotoViewAdapter.OnItemChangeListener() {
int len = imgUrls.size();
@Override
public void onItemChange(int currentPosition) {
//滑动到总图片数目的几分之几
// headTitle.setText((currentPosition+1) + "/" + len); }
});
mViewPager = (ViewPager)findViewById(R.id.viewer);
mViewPager.setOffscreenPageLimit(3);
mViewPager.setAdapter(pagerAdapter);
mViewPager.setCurrentItem(position);
} @Override
protected void initView() { } @Override
protected void initTitleView() { } @Override
protected void click(View view) { } }
PhotoViewAdapter代码可参考:
 
loopviewpager包下代码可参考:
https://github.com/tianshaojie/AndroidFine/tree/master/app/src/main/java/com/yuzhi/fine/ui/loopviewpager

android项目实战 --ListView 头部ViewPager广告轮询图效果的更多相关文章

  1. Android开发之ViewPager实现轮播图(轮播广告)效果的自定义View

    最近开发中需要做一个类似京东首页那样的广告轮播效果,于是采用ViewPager自己自定义了一个轮播图效果的View. 主要原理就是利用定时任务器定时切换ViewPager的页面. 效果图如下: 主页面 ...

  2. Android项目实战(四十七):轮播图效果Viewpager

    简易.常用的轮播图效果ViewPager ,老技术了,记一笔留着以后ctrl C + ctrl V    需求如下: 不定张个数的ImagView轮播,右下角显示轮播点图标,每隔固定时间切换下一张,最 ...

  3. (转载)Android项目实战(二十八):使用Zxing实现二维码及优化实例

    Android项目实战(二十八):使用Zxing实现二维码及优化实例 作者:听着music睡 字体:[增加 减小] 类型:转载 时间:2016-11-21我要评论 这篇文章主要介绍了Android项目 ...

  4. Android项目实战(二十九):酒店预定日期选择

    先看需求效果图: 几个需求点: 1.显示当月以及下个月的日历 (可自行拓展更多月份) 2.首次点击选择"开始日期",再次点击选择"结束日期" (1).如果&qu ...

  5. Android项目实战--手机卫士开发系列教程

    <ignore_js_op> banner131010.jpg (71.4 KB, 下载次数: 0) 下载附件  保存到相册 2 分钟前 上传   Android项目实战--手机卫士01- ...

  6. Android项目实战(四十九):Andoird 7.0+相机适配

    解决方案类似: Android项目实战(四十):Andoird 7.0+ 安装APK适配 解决方法: 一.在AndroidManifest.xml 文件中添加 四大组件之一的 <provider ...

  7. Android项目实战(三十二):圆角对话框Dialog

    前言: 项目中多处用到对话框,用系统对话框太难看,就自己写一个自定义对话框. 对话框包括:1.圆角 2.app图标 , 提示文本,关闭对话框的"确定"按钮 难点:1.对话框边框圆角 ...

  8. (转载)Android项目实战(三十二):圆角对话框Dialog

    Android项目实战(三十二):圆角对话框Dialog   前言: 项目中多处用到对话框,用系统对话框太难看,就自己写一个自定义对话框. 对话框包括:1.圆角 2.app图标 , 提示文本,关闭对话 ...

  9. (转载)Android项目实战(二十七):数据交互(信息编辑)填写总结

    Android项目实战(二十七):数据交互(信息编辑)填写总结   前言: 项目中必定用到的数据填写需求.比如修改用户名的文字编辑对话框,修改生日的日期选择对话框等等.现总结一下,方便以后使用. 注: ...

随机推荐

  1. swift设置textfield边框颜色

    //swift3.0,如果是2.0的话也可以照着这个样子去写,语法有所变动.根据联想出来的就可以了. let tx = UITextField(frame: CGRect(x: 100, y: 100 ...

  2. [ios] NSURL

    NSLog(@“Scheme: %@”, [url scheme]); NSLog(@“Host: %@”, [url host]); NSLog(@“Port: %@”, [url port]); ...

  3. [翻译]Eureka一窥

    什么是Eureka? Eureka是一个基于REST的服务,主要用在AWS云环境作为服务发现,负载均衡和失败转移.我们叫这个服务,Eureka服务. Eureka也有一个JAVA客户端组件, Eure ...

  4. quagga源码分析--大内总管zebra

    zebra,中文翻译是斑马,于是我打开了宋冬野的<斑马,斑马>作为BGM来完成这个篇章,嘿嘿,小资一把! zebra姑且戏称它是quagga项目的大内总管. 因为它负责管理其他所有协议进程 ...

  5. CodeForces 749D Leaving Auction

    二分查找,$set$. 对于某一次询问,如果把人删光了,那么输出$0$ $0$. 如果只剩下$1$个人,那么输出那个人喊的最低价格. 如果剩下的人数有大于等于两个, 这时最底下出现的情景必然是红色部分 ...

  6. 为什么需要DevOps

    过去一年以来,一批来自欧美的.不墨守陈规的系统管理员和开发人员一直在谈论一个新概念:DevOps.DevOps 就是开发(Development) 和运维(Operations)这两个领域的合并.(如 ...

  7. wpf ProgressBar使用

    wpf     progressBar使用起来有些麻烦,直接设置value的值还不行 而是通过委托来执行setValue方法 //Create a Delegate that matches the ...

  8. OBIEE 缓存机制

    1,EM下开关缓存和rpd中高速缓存是一件事,就是nqserver的缓存, 由nqsconfig.ini中配置决定cache是否开启. 当然rpd里面还需要设置,具体的表是否要缓存. 这部分可以看这篇 ...

  9. CODE[VS]-寻找子串位置-字符串处理-天梯青铜

    题目描述 Description 给出字符串a和字符串b,保证b是a的一个子串,请你输出b在a中第一次出现的位置. 输入描述 Input Description 仅一行包含两个字符串a和b 输出描述 ...

  10. CodeForces 712D Memory and Scores

    $dp$,前缀和. 记$dp[i][j]$表示$i$轮结束之后,两人差值为$j$的方案数. 转移很容易想到,但是转移的复杂度是$O(2*k)$的,需要优化,观察一下可以发现可以用过前缀和来优化. 我把 ...