android项目实战 --ListView 头部ViewPager广告轮询图效果

- 导入photoview相关代码:


<?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>
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();
}
}
<?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>
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) {
}
}
android项目实战 --ListView 头部ViewPager广告轮询图效果的更多相关文章
- Android开发之ViewPager实现轮播图(轮播广告)效果的自定义View
最近开发中需要做一个类似京东首页那样的广告轮播效果,于是采用ViewPager自己自定义了一个轮播图效果的View. 主要原理就是利用定时任务器定时切换ViewPager的页面. 效果图如下: 主页面 ...
- Android项目实战(四十七):轮播图效果Viewpager
简易.常用的轮播图效果ViewPager ,老技术了,记一笔留着以后ctrl C + ctrl V 需求如下: 不定张个数的ImagView轮播,右下角显示轮播点图标,每隔固定时间切换下一张,最 ...
- (转载)Android项目实战(二十八):使用Zxing实现二维码及优化实例
Android项目实战(二十八):使用Zxing实现二维码及优化实例 作者:听着music睡 字体:[增加 减小] 类型:转载 时间:2016-11-21我要评论 这篇文章主要介绍了Android项目 ...
- Android项目实战(二十九):酒店预定日期选择
先看需求效果图: 几个需求点: 1.显示当月以及下个月的日历 (可自行拓展更多月份) 2.首次点击选择"开始日期",再次点击选择"结束日期" (1).如果&qu ...
- Android项目实战--手机卫士开发系列教程
<ignore_js_op> banner131010.jpg (71.4 KB, 下载次数: 0) 下载附件 保存到相册 2 分钟前 上传 Android项目实战--手机卫士01- ...
- Android项目实战(四十九):Andoird 7.0+相机适配
解决方案类似: Android项目实战(四十):Andoird 7.0+ 安装APK适配 解决方法: 一.在AndroidManifest.xml 文件中添加 四大组件之一的 <provider ...
- Android项目实战(三十二):圆角对话框Dialog
前言: 项目中多处用到对话框,用系统对话框太难看,就自己写一个自定义对话框. 对话框包括:1.圆角 2.app图标 , 提示文本,关闭对话框的"确定"按钮 难点:1.对话框边框圆角 ...
- (转载)Android项目实战(三十二):圆角对话框Dialog
Android项目实战(三十二):圆角对话框Dialog 前言: 项目中多处用到对话框,用系统对话框太难看,就自己写一个自定义对话框. 对话框包括:1.圆角 2.app图标 , 提示文本,关闭对话 ...
- (转载)Android项目实战(二十七):数据交互(信息编辑)填写总结
Android项目实战(二十七):数据交互(信息编辑)填写总结 前言: 项目中必定用到的数据填写需求.比如修改用户名的文字编辑对话框,修改生日的日期选择对话框等等.现总结一下,方便以后使用. 注: ...
随机推荐
- Mvc分页组件MvcSimplePager代码重构
1 Mvc分页组件MvcSimplePager代码重构 1.1 Intro 1.2 MvcSimplePager 代码优化 1.3 MvcSimplePager 使用 1.4 End Mvc分页组件M ...
- spring-mvc + shiro框架整合(sonne_game网站开发04)
这篇文章讲的内容是在之前spring + mybatis + spring-mvc + freemarker框架整合的代码的基础上.有需要的可以看看我博客的前两篇文章. 另外,本文章所讲相关所有代码都 ...
- D3.js:饼状图的制作
假设有如下数据需要可视化: var dataset = [ 30 , 10 , 43 , 55 , 13 ]; 这样的值是不能直接绘图的.例如绘制饼状图的一个部分,需要知道一段弧的起始角度和终止角度, ...
- JavaWeb开发中的乱码问题
一,获取系统平台的默认编码 获取系统平台的默认编码: String encoding=System.getProperty("file.encoding"); 注:至于UTF-8编 ...
- C#笔记(二)变量之预定义的引用类型
1.object类型 在C#中, object类型就是最终的父类型,所有内置类型和用户定义的类型都从它派生而 来. 这样, object类型就可以用于两个目的了: 可以使用object引用绑定任何子类 ...
- netty高级篇(3)-HTTP协议开发
一.HTTP协议简介 应用层协议http,发展至今已经是http2.0了,拥有以下特点: (1) CS模式的协议 (2) 简单 - 只需要服务URL,携带必要的请求参数或者消息体 (3) 灵活 - 任 ...
- 【angular】angular实现简单的tab切换
html: <div class="list-group" ng-repeat="tab in menuList"> <a href=&quo ...
- Vim插件之Command-T使用问题
最近在使用vim插件CommandT时出现问题其实就是vim没有支持ruby,不过google之后找到了解决方法,老外的态度还是很让人敬佩的,度娘搜索的结果太让人呕心了.. 贴下,以后再次遇到解决. ...
- android 实现与服务器的长链接 方式
http://blog.csdn.net/coffeeco/article/details/13276437 这边文章主要看服务端,使用tomcat7以上实现服务端的接收消息以及消息发送 http: ...
- layer ifram 弹出框
父层 <div class="col-xs-4 text-left" style="padding-left: 50px;"><button ...