GridView的边框效果
来源:互联网 发布:网络远程教育怎么考试 编辑:程序博客网 时间:2024/04/28 14:48
因为项目需求的原因需要实现这种效果,通过看android gallery模块源码了解到原来这种效果是通过selector实现的
在android:state_window_focused="false"状态的时候用一张中间透明灰色边框图片
在android:state_pressed="true"状态的时候用一张中间透明黄色边框的图片即可实现
实现如下:
GridViewUsagepackage com.android.GridView;import android.app.Activity;import android.os.Bundle;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import android.widget.AdapterView;import android.widget.BaseAdapter;import android.widget.GridView;import android.widget.ImageView;public class GridViewUsage extends Activity implementsGridView.OnItemClickListener {int[] image = { R.drawable.mb5u10_mb5ucom, R.drawable.mb5u11_mb5ucom,R.drawable.mb5u12_mb5ucom, R.drawable.mb5u13_mb5ucom,R.drawable.mb5u14_mb5ucom, R.drawable.mb5u15_mb5ucom,R.drawable.mb5u16_mb5ucom, R.drawable.mb5u17_mb5ucom,R.drawable.mb5u18_mb5ucom, R.drawable.mb5u19_mb5ucom,};/** Called when the activity is first created. */@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.main);GridView gv = (GridView) findViewById(R.id.gride);ImageList adapter = new ImageList(this);gv.setAdapter(adapter);gv.setOnItemClickListener(this);}public class ImageList extends BaseAdapter {Activity activity;LayoutInflater inflater;// constructpublic ImageList(Activity a) {activity = a;inflater = LayoutInflater.from(activity);}@Overridepublic int getCount() {return image.length;}@Overridepublic Object getItem(int position) {return image[position];}@Overridepublic long getItemId(int position) {return position;}@Overridepublic View getView(int position, View convertView, ViewGroup parent) {ImageView im = new ImageView(activity);if (convertView == null) {convertView = inflater.inflate(R.layout.item_grid, null);im = (ImageView) convertView.findViewById(R.id.iv_image);convertView.setTag(im);}else{im = (ImageView) convertView.getTag();}im.setImageResource(image[position]);return convertView;}}@Overridepublic void onItemClick(AdapterView<?> arg0, View view, int positon, long id) {}}
main.xml
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" > <GridView android:id="@+id/gride" android:layout_width="wrap_content" android:layout_height="wrap_content" android:numColumns="3" android:listSelector="@android:color/transparent" android:scrollbars="none" /></LinearLayout>
android:listSelector属性设置比较重要,在这里要设置为透明效果,因为边框效果会在imageView的background属性里面来设置
item_grid.xml
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" > <ImageView android:id="@+id/iv_image" android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="@drawable/grid_selector_background" /></LinearLayout>
grid_selector_background.xml
<?xml version="1.0" encoding="utf-8"?><selector xmlns:android="http://schemas.android.com/apk/res/android"> <item android:state_window_focused="false" android:drawable="@drawable/frame_gallery_preview_album" /> <item android:state_selected="true" android:drawable="@drawable/frame_gallery_preview_album_pressed" /> <item android:state_pressed="true" android:drawable="@drawable/frame_gallery_preview_album_pressed" /></selector>
最终效果图如下:
源码下载地址:http://download.csdn.net/detail/sanjinxiong/3978206
- GridView的边框效果
- GridView边框效果
- 为GridView添加边框效果
- 去掉Gridview显示的边框
- 字体边框的光晕效果
- 多重panel的边框效果
- GridView内边框设置的问题
- gridview+div的ToopTip效果
- gridview中onmouseover的效果
- Gridview中onmouseover的效果
- GridView模拟Gallery的效果
- 取消GridView 的点击效果
- 自定义瓷砖效果的GridView
- ListView实现GridView的效果
- 创建灵活的CSS2边框效果
- 表格边框鲜用的效果
- 简单实用的图片边框效果
- javaScript简单的表格边框闪烁效果。
- 移动设备游戏设计规划和制作技巧
- PHP压缩与解压缩PCLZIP(标准版)
- Java Future接口简介
- 第二代Snapdragon
- 清华大学2012年博士研究生招生专业目录
- GridView的边框效果
- 度量满足条件——非负性、对称性和三角不等式
- iOS 属性的属性
- The Eclipse JDT Core jar is not in the classpath
- Sql 语句的一些用法
- xhtml 标准事件
- Activity的四种加载模式
- 利用expdp/impdp实现表空间转移功能
- Android应用开发之SharedPreferes