android gallery 自定义边框+幻灯片效果
最近在项目中用到图片轮播,试了Gallery,ViewFlipper,ViewPager,感觉Gallery最符合需求,但是Gallery的系统边框很难看,项目中要求用自己的背景图片。
下面来看一下使用Gallery实现图片轮播
运行效果:

布局文件:
- <FrameLayout
- android:layout_width="fill_parent"
- android:layout_height="wrap_content"
- android:paddingLeft="16dp"
- android:paddingRight="16dp"
- android:paddingTop="10dp" >
- <Gallery
- android:id="@+id/gallery"
- android:layout_width="fill_parent"
- android:layout_height="wrap_content"
- android:fadingEdge="none"
- android:spacing="0dp" />
- <RelativeLayout
- android:layout_width="fill_parent"
- android:layout_height="18dp"
- android:layout_gravity="bottom"
- android:layout_marginBottom="3dp"
- android:layout_marginLeft="3dp"
- android:layout_marginRight="3dp"
- android:background="#80776f63"
- android:gravity="center" >
- <ImageView
- android:id="@+id/dot_1"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:src="@drawable/ic_dot_normal" />
- <ImageView
- android:id="@+id/dot_2"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:layout_marginLeft="10dp"
- android:layout_toRightOf="@+id/dot_1"
- android:src="@drawable/ic_dot_normal" />
- <ImageView
- android:id="@+id/dot_3"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:layout_marginLeft="10dp"
- android:layout_marginRight="10dp"
- android:layout_toRightOf="@+id/dot_2"
- android:src="@drawable/ic_dot_normal" />
- </RelativeLayout>
- </FrameLayout>
其中, android:fadingEdge="none"消除图片两边的阴影。使用FrameLayout在底部显示小圆点
- public class MainActivity extends Activity {
- private Gallery mGallery;
- private int index = 0;// 记录选中的图片位置
- private ImageView[] mImageViewIds;// 小圆点ImageView数组
- private static final int IMAGE_COUNT = 3;// 小圆点个数
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_main);
- findViews();
- mImageViewIds[0].setImageDrawable(getBaseContext().getResources()
- .getDrawable(R.drawable.ic_dot_focused));
- ImageAdapteradapter = new ImageAdapter(this);
- mGallery.setAdapter(adapter);
- Timer timer = new Timer();
- timer.schedule(task, 2000, 2000);
- mGallery.setOnItemSelectedListener(onItemSelectedListener);
- mGallery.setOnItemClickListener(onItemClickListener);
- }
- private void findViews() {
- mGallery = (Gallery) findViewById(R.id.gallery);
- mImageViewIds = new ImageView[] { (ImageView) findViewById(R.id.dot_1),
- (ImageView) findViewById(R.id.dot_2),
- (ImageView) findViewById(R.id.dot_3) };
- }
- private TimerTask task = new TimerTask() {
- @Override
- public void run() {
- Message message = new Message();
- message.what = 2;
- index = mGallery.getSelectedItemPosition();
- index++;
- handler.sendMessage(message);
- }
- };
- /**
- * 开一个线程执行耗时操作
- */
- private Handler handler = new Handler() {
- @Override
- public void handleMessage(Message msg) {
- super.handleMessage(msg);
- switch (msg.what) {
- case 2:
- mGallery.setSelection(index);
- break;
- default:
- break;
- }
- }
- };
- /**
- * 设置小圆点显示,position会一直增加,如果要循环显示图片,需要对position取余,否则数组越界
- */
- private OnItemSelectedListener onItemSelectedListener = new OnItemSelectedListener() {
- @Override
- public void onItemSelected(AdapterView<?> parent, View view,
- int position, long id) {
- int pos = position % IMAGE_COUNT;
- mImageViewIds[pos].setImageDrawable(getBaseContext().getResources()
- .getDrawable(R.drawable.ic_dot_focused));
- if (pos > 0) {
- mImageViewIds[pos - 1].setImageDrawable(getBaseContext()
- .getResources().getDrawable(R.drawable.ic_dot_normal));
- }
- if (pos < (IMAGE_COUNT - 1)) {
- mImageViewIds[pos + 1].setImageDrawable(getBaseContext()
- .getResources().getDrawable(R.drawable.ic_dot_normal));
- }
- if (pos == 0) {
- mImageViewIds[IMAGE_COUNT - 1]
- .setImageDrawable(getBaseContext().getResources()
- .getDrawable(R.drawable.ic_dot_normal));
- }
- }
- @Override
- public void onNothingSelected(AdapterView<?> arg0) {
- // TODO Auto-generated method stub
- }
- };
- /**
- * 点击事件,点击图片进入SecondActivity
- */
- private OnItemClickListener onItemClickListener = new OnItemClickListener() {
- @Override
- public void onItemClick(AdapterView<?> arg0, View arg1, int pos,
- long arg3) {
- Intent intent = new Intent();
- intent.setClass(MainActivity.this, SecondActivity.class);
- startActivity(intent);
- }
- };
- }
ImageAdapter类,重写android.widget.BaseAdapter,用于描述图像信息。
- public class ImageAdapter extends BaseAdapter {
- private Context context;
- private int[] mImages = { R.drawable.bg_timeline_01,
- R.drawable.bg_timeline_02, R.drawable.bg_timeline_03 };
- private static final int IMAGE_PX_HEIGHT = 198;
- public ImageAdapter(Context context) {
- this.context = context;
- }
- @Override
- public int getCount() {
- return Integer.MAX_VALUE;//实现循环显示
- }
- @Override
- public Object getItem(int position) {
- return position;
- }
- @Override
- public long getItemId(int position) {
- return position;
- }
- @Override
- public View getView(int position, View convertView, ViewGroup parent) {
- ImageView imageView = new ImageView(context);
- imageView.setImageResource(mImages[position % mImages.length]);
- imageView.setScaleType(ImageView.ScaleType.CENTER);
- imageView.setLayoutParams(new Gallery.LayoutParams(
- Gallery.LayoutParams.FILL_PARENT, IMAGE_PX_HEIGHT));
- RelativeLayout borderImg = new RelativeLayout(context);
- borderImg.setPadding(2, 2, 2, 2);
- borderImg.setBackgroundResource(R.drawable.bg_gallery);//设置ImageView边框
- borderImg.addView(imageView);
- return borderImg;
- }
- }
如果用系统背景,可以这样写
- int mGalleryItemBackground;
- private Context mContext;
- public ImageAdapter(Context context)
- {
- mContext = context;
- // 获得Gallery组件的属性
- TypedArray typedArray = obtainStyledAttributes(R.styleable.Gallery);
- mGalleryItemBackground = typedArray.getResourceId(
- R.styleable.Gallery_android_galleryItemBackground, 0);
- }
在getview中设置
- imageView.setBackgroundResource(mGalleryItemBackground);
Gallery组件属性信息定义在res\values\attrs.xml
- <?xml version="1.0" encoding="utf-8"?>
- <resources>
- <declare-styleable name="Gallery">
- <attr name="android:galleryItemBackground" />
- </declare-styleable>
- </resources>
详细讲解见http://www.eoeandroid.com/forum.php?mod=viewthread&tid=182297
自定义边框参考http://stackoverflow.com/questions/4830173/change-border-style-in-gallery
android gallery 自定义边框+幻灯片效果的更多相关文章
- android gallery 自定义边框+幻灯片
最近在项目中用到图片轮播,试了Gallery,ViewFlipper,ViewPager,感觉Gallery最符合需求,但是Gallery的系统边框很难看,项目中要求用自己的背景图片. 下面来看一下使 ...
- Android checkbox 自定义点击效果
安卓默认的效果 自定义后的效果 前面的图片当然可以自己修改. 实现这个效果的步骤如下 1.建立 一个selector 的xml <?xml ver ...
- Android之EditText自定义边框和边框颜色(转载)
介绍一种比较常见的用法 第一步:准备两张图片大小一样,颜色不同的图片.图片名称分为:editbox_focus.png和editbox_normal.png 放入工程的drawable文件夹下. 第二 ...
- Android之Button自定义点击效果
我们在界面上经常会用到button按钮,但通常button点击后看不到点击的效果,如果用户连续点击了两次,就会报NAR错误,这样交互性就比较差了.如果我们自定义了button点击效果,比如我们点击了b ...
- Android 自定义View修炼-【2014年最后的分享啦】Android实现自定义刮刮卡效果View
一.简介: 今天是2014年最后一天啦,首先在这里,我祝福大家在新的2015年都一个个的新健康,新收入,新顺利,新如意!!! 上一偏,我介绍了用Xfermode实现自定义圆角和椭圆图片view的博文& ...
- Android自定义类似ProgressDialog效果的Dialog
Android自定义类似ProgressDialog效果的Dialog. 方法如下: 1.首先准备两张自己要定义成哪样子的效果的图片和背景图片(也可以不要背景). 如我要的效果: 2.定义loadin ...
- 50个Android开发人员必备UI效果源码[转载]
50个Android开发人员必备UI效果源码[转载] http://blog.csdn.net/qq1059458376/article/details/8145497 Android 仿微信之主页面 ...
- [转载] 50个Android开发人员必备UI效果源码
好东西,多学习! Android 仿微信之主页面实现篇Android 仿微信之界面导航篇Android 高仿QQ 好友分组列表Android 高仿QQ 界面滑动效果Android 高仿QQ 登陆界面A ...
- Android自定义控件 -- 带边框的TextView
使用xml实现边框 原来使用带边框的TextView时一般都是用XML定义来完成,在drawable目录中定义如下所示的xml文件: <?xml version="1.0" ...
随机推荐
- 「UOJ218」火车管理
「UOJ218」火车管理 解题思路:观察发现,在弹出 \(x\) 之前,它前面这个元素都是保持不变的,所以可以用一棵可持久化线段树维护每一个栈顶元素的插入时间,每次找到当前时间\(-1\) 的版本就可 ...
- [BZOJ3143][HNOI2013]游走(期望+高斯消元)
3143: [Hnoi2013]游走 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 3576 Solved: 1608[Submit][Status ...
- HDU1251 统计难题 trie树 简单
http://acm.hdu.edu.cn/showproblem.php?pid=1251 题意: 找前缀数量 裸模板 #include<cstdio> #include<cstr ...
- fir.im Weekly - 嘘,关于***!
上 Github 交友刷 StackOverflow 解惑,是攻城狮必备技能,加快打怪练级速度.关于,@左耳朵耗子 在微博上分享了一篇文档,轻一点教你建一个VPN服务器,重一点到教你在路由器上***, ...
- 高斯消元法求解异或方程组: cojs.tk 539.//BZOJ 1770 牛棚的灯
高斯消元求解异或方程组: 比较不错的一篇文章:http://blog.sina.com.cn/s/blog_51cea4040100g7hl.html cojs.tk 539. 牛棚的灯 ★★☆ ...
- PHP -- 函数基础入门
FROM : http://www.cnblogs.com/kym/archive/2010/02/14/1668300.html, http://www.cnblogs.com/kym/archiv ...
- 常用SQL Server规范集锦及优化
原文地址:http://www.cnblogs.com/liyunhua/p/4526195.html
- 人脸检测:微软 VS Face++
近些年国内的人脸技术已经得到了很大的发展,今天网上无意看到了微软和face++两家公司的人脸检测,Face++号称国际顶尖的技术,也用过他们的接口感觉确实很不错,而微软则不再话下了.于是想对比微软和F ...
- HTTP协议返回状态码说明
http://1632004.blog.163.com/blog/static/29991497201231811231120/ 如果向您的服务器发出了某项请求要求显示您网站上的某个网页(例如,当用户 ...
- Can a windows dll retrieve its own filename?
http://stackoverflow.com/questions/2043/can-a-windows-dll-retrieve-its-own-filename A windows exe fi ...