Android利用GridView实现单选效果

1.实现如图所示的单选效果

由于Android提供的单选按钮radiobutton只能单行或单列显示,且样式并不美观,故可用GridView进行改造,实现单选效果,而要实现这样的效果重点就在GridView的适配器这块了。

首先是GridView的item的XML:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
 <RelativeLayout
  android:id="@+id/options"
  android:layout_width="match_parent"
  android:layout_height="143dp">
  <ImageView
   android:id="@+id/imageView"
   android:layout_width="65dp"
   android:layout_height="65dp"/>
  <TextView
   android:id="@+id/textView"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:layout_centerInParent="true"
   android:text="通讯录"/>
 </RelativeLayout>
</LinearLayout>

里边很简单,就只用来放显示选中效果的imageView和文字的textView

接下来是适配器:

public class GridViewRadioAdapter extends BaseAdapter {
 private Context mContext;
 private int lastPosition = -1;   //记录上一次选中的图片位置,默认不选中
 private String[] str = null;    //放问题内容文字的数组

 public GridViewRadioAdapter(Context mContext) {
  this.mContext = mContext;
 }

 public void setStr(String[] str){  //在activity中调用此方法传入问题的数组
  this.str = str;
 }

 public void setSelection(int position) { //在activity中GridView的onItemClickListener中调用此方法,来设置选中位置
  lastPosition = position;
 }

 @Override
 public int getCount() {
  return str.length;
 }

 @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) {
  ViewHolder viewHolder = null;
  if (convertView == null){
   viewHolder = new ViewHolder();
   convertView = LayoutInflater.from(mContext).inflate(R.layout.adapter_gridview_radio_item, null);
   viewHolder.textView = (TextView) convertView.findViewById(R.id.textView);
   viewHolder.imageView = (ImageView) convertView.findViewById(R.id.imageView);
   viewHolder.relativeLayout = (RelativeLayout) convertView.findViewById(R.id.options);
   convertView.setTag(viewHolder);
  }else {
   viewHolder = (ViewHolder) convertView.getTag();
  }
  viewHolder.textView.setText(str[position]);
  if (lastPosition == position){ //判断是否为选中项,选中项与非选中项设置不同的样式
   switch (position){  //选中状态下设置样式
    case 0:
     viewHolder.imageView.setBackgroundResource(R.drawable.option_a_checked);
     break;
    case 1:
     viewHolder.imageView.setBackgroundResource(R.drawable.option_b_checked);
     break;
    case 2:
     viewHolder.imageView.setBackgroundResource(R.drawable.option_c_checked);
     break;
    case 3:
     viewHolder.imageView.setBackgroundResource(R.drawable.option_d_checked);
     break;
   }
   viewHolder.relativeLayout.setBackgroundResource(R.drawable.shape_rect_orange);
  }else {  //非选中状态下设置样式
   switch (position){
    case 0:
     viewHolder.imageView.setBackgroundResource(R.drawable.option_a);
     break;
    case 1:
     viewHolder.imageView.setBackgroundResource(R.drawable.option_b);
     break;
    case 2:
     viewHolder.imageView.setBackgroundResource(R.drawable.option_c);
     break;
    case 3:
     viewHolder.imageView.setBackgroundResource(R.drawable.option_d);
     break;
   }
   viewHolder.relativeLayout.setBackgroundResource(R.drawable.shape_rect_gray);
  }
  return convertView;
 }

 class ViewHolder{
  private TextView textView;
  private ImageView imageView;
  private RelativeLayout relativeLayout;
 }
}

最后在activity中设置适配器:

GridViewRadioAdapter adapter = new GridViewRadioAdapter(mContext);
adapter.setStr(options); //传入问题的选项
mGridView.setAdapter(adapter);
mGridView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
 @Override
 public void onItemClick(AdapterView<?> arg0, View arg1, int position, long arg3) {
  adapter.setSelection(position); //传值更新
  adapter.notifyDataSetChanged(); //每一次点击通知adapter重新渲染
 }
}); 

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持我们!

(0)

相关推荐

  • Android利用GridView实现单选功能

    先看看GridView实现单选效果 如果是你需要的,你可以继续往下看了 实现起来比较简单,直接上代码 主Activity的布局,一个Button用来跳转到筛选Activity一个TextView用来显示筛选后的到的结果 <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/androi

  • 详谈自定义View之GridView单选 金额选择Layout-ChooseMoneyLayout

    思路: 外层控件用的是GridView,里面每个item放一个FrameLayout,FrameLayout里面有Checkbox和ImageView,chechBox添加background实现选中效果,选中背景为透明,显示item的勾勾图标,不选中checkbox就有背景,挡住选中的勾勾..重写GridView,实现监听和数据适配,用一个接口返回选中的数据. 代码: ChooseMoneyLayout.java public class ChooseMoneyLayout extends G

  • Android利用GridView实现单选效果

    1.实现如图所示的单选效果 由于Android提供的单选按钮radiobutton只能单行或单列显示,且样式并不美观,故可用GridView进行改造,实现单选效果,而要实现这样的效果重点就在GridView的适配器这块了. 首先是GridView的item的XML: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical&

  • Android 利用ViewPager+GridView实现首页导航栏布局分页效果

    最近我尝试使用ViewPager+GridView实现的,看起来一切正常,废话不多说,具体代码如下: 如图是效果图 首先分析下思路 1.首先是怎么布局:整体是一个ViewPager将GridView作为一个View添加到ViewPager的adapter中,下方是圆点 <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.a

  • Android 利用ViewPager实现图片可以左右循环滑动效果附代码下载

    首先给大家展示靓照,对效果图感兴趣的朋友可以继续往下阅读哦. ViewPager这个小demo实现的是可以左右循环滑动图片,下面带索引,滑到最后一页在往右滑动就要第一页,第一页往左滑动就到最后一页,上面是效果图,用美女图片是我一贯的作风,呵呵  1.    首先看一些layout下的xml <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width=&qu

  • Android利用悬浮按钮实现翻页效果

    今天给大家分享下自己用悬浮按钮点击实现翻页效果的例子. 首先,一个按钮要实现悬浮,就要用到系统顶级窗口相关的WindowManager,WindowManager.LayoutParams.那么在AndroidManifest.xml中添加权限: <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" /> 然后,我们要对WindowManager,WindowManager.Layout

  • Android RecyclerView详解之实现 ListView GridView瀑布流效果

     什么是RecyclerView RecyclerView 是Google推出的最新的 替代ListView.GridView的组件,RecyclerView是用来显示大量数据的容器,并通过有限数量的子View,来提高滚动时的性能. 与ListView不同,RecyclerView 不再负责布局,而是专注于布局复用.布局主要通过 LayoutManager来管理,目前提供了3种常用的布局管理: LinearLayoutManager 线性布局管理器 (ListView效果) GridLayout

  • Android GridView实现动画效果实现代码

     Android GridView实现动画效果 项目中用到的一些动画,GridView的Item依次从屏幕外飞入到相应位置,附上相关代码: MainActivity.Java package com.mundane.gridanimationdemo; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.view.View; import android.view.an

  • Android实现GridView中的item自由拖动效果

    之前的工作中,需要实现一个功能就是GridView中的item可以自由拖动, 思考了一下,其实实现起来不是很困难,主要工作就是交换节点,以及拖动时的移动效果,下面讲讲具体的实现: 首先声明一个BaseAdapter: package com.dafasoft.dragablegridview; import android.content.Context; import android.view.LayoutInflater; import android.view.View; import a

  • Android利用ViewPager实现用户引导界面效果的方法

    本文实例讲述了Android利用ViewPager实现用户引导界面效果.分享给大家供大家参考,具体如下: 我相信有很多朋友在装完软件首次打开时,有很多软件都有一个软件功能介绍, 例如刚装完微信打开它,有很多介绍微信功能的图片,并且在屏幕下方有很多小圆点提示你当前图片的位置. 今天我就来实现这么个功能 所实现的功能: 1.可以左右滑动功能图片. 2.图片的索引 看出当前图片所在的位置. 3.可循环滑动. 4.图片的索引带有动画效果. 本次学习主要是利用ViewPager实现用户引导界面 在这里,我

  • Android中listview和imageview实现条目单选效果

    前段时间在项目开发中,有listview实现单选和多选的效果,特别是listview的单选效果,一开始项目比较紧,自己考虑的是用listview和radionbutton实现的,可能是自己考虑不周到的原因,效果是实现了,但是用户体验不怎么好,做完项目后,自己又弄了下,使用listview和imageview实现,点击listview条目的时候就可以实现单选效果,这样用户体验就稍微好些.以下就是实现的方式: activity_main.xml文件: <RelativeLayout xmlns:an

随机推荐