前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android实现为GridView添加边框效果

Android实现为GridView添加边框效果

作者头像
砸漏
发布2020-10-29 22:36:51
1.4K0
发布2020-10-29 22:36:51
举报
文章被收录于专栏:恩蓝脚本恩蓝脚本

为GridView添加边框效果,供大家参考,具体内容如下

1.自定义GridView的item样式:

grid_item.xml文件

代码语言:javascript
复制
<?xml version="1.0" encoding="utf-8"?  
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  android:layout_width="wrap_content" 
  android:layout_height="wrap_content"   
  <ImageView 
    android:id="@+id/item_image" 
    android:layout_width="115dp" 
    android:layout_height="115dp" 
    android:padding="8dp" 
    android:background="@drawable/grid_selector"  
    /  
</LinearLayout  

2.设置GridView item的背景: grid_selector.xml文件

代码语言:javascript
复制
<?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/grid_normal" /   
  <item android:state_selected="true" 
    android:drawable="@drawable/grid_pressed" /     
  <item android:state_pressed="true" 
    android:drawable="@drawable/grid_pressed" /  
</selector  

3.设置GridView的listSelector为透明:

代码语言:javascript
复制
android:listSelector="@android:color/transparent" 

4.自定义GridView的adapter:

代码语言:javascript
复制
import java.util.ArrayList; 
import android.content.Context; 
import android.graphics.drawable.Drawable; 
import android.view.LayoutInflater; 
import android.view.View; 
import android.view.ViewGroup; 
import android.widget.BaseAdapter; 
import android.widget.ImageView; 
 
public class GridAdapter extends BaseAdapter { 
  private Context mContext = null; 
  private LayoutInflater inflater = null; 
  private ArrayList<Drawable  drawableList = null; 
 
  public GridAdapter(Context c) { 
    this.mContext = c; 
    this.inflater = LayoutInflater.from(mContext); 
  } 
  public void setDataSource(ArrayList<Drawable  list){ 
    this.drawableList = list; 
  } 
  public int getCount() { 
    if(drawableList != null){ 
      return drawableList.size(); 
    }else{ 
      return 0; 
    } 
  } 
 
  public Object getItem(int position) { 
    return drawableList.get(position); 
  } 
 
  public long getItemId(int position) { 
    return position; 
  } 
 
  public View getView(int position, View convertView, ViewGroup parent) { 
 
    ImageView imageView = new ImageView(mContext); 
    if (convertView == null) { 
      convertView = inflater.inflate(R.layout.grid_item, null); 
      imageView = (ImageView) convertView.findViewById(R.id.item_image); 
      imageView.setScaleType(ImageView.ScaleType.CENTER_INSIDE); 
      convertView.setTag(imageView); 
    } else { 
      imageView = (ImageView) convertView.getTag(); 
    } 
    imageView.setImageDrawable(drawableList.get(position)); 
    return convertView; 
  } 
} 

以上就是本文的全部内容,希望对大家的学习有所帮助。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档