[置顶] Android RadioButton与TextView浪漫约会?
情景一
今天主要实现一个国家与地区切换,就是当我们选中RadioButton时然后将值设置到TextView中,听着这需求应该不难对吧?那么我们就开始约会吧?
看下原型图
准备条件:
- 首先需要一个radiobutton然后一个textview作为子item
- 需要一个适配器这里不再多赘述
- 需要写回调方法 void onItemClickListener(int position);
- 在主Activity 需要将适配器与数据源绑定然后进行回调将当前选中的标题设置到textview中
下面看下具体的实现流程
1、看下布局文件子item radiobutton.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent">
<RadioGroup
android:id="@+id/rg_area"
android:layout_alignParentTop="true"
android:layout_marginBottom="20dp"
android:layout_width="wrap_content"
android:layout_height="wrap_content">
/>
</RadioGroup>
<RadioButton
android:id="@+id/radio"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_marginTop="10dp"
android:button="@drawable/check_box_selected"
android:background="@null"
android:focusable="true"
android:checked="false"
android:clickable="true"
android:layout_marginRight="10dp"/>
<TextView
android:id="@+id/tv_country_and_area"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_marginTop="10dp"
android:text="香港"
android:layout_marginLeft="10dp"
android:textSize="22sp"/>
</RelativeLayout>
效果
- 适配器RadioAdapter实现
package com.visoport.medicine.ui.activity.adapter;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.CompoundButton;
import android.widget.RadioButton;
import android.widget.TextView;
import android.widget.Toast;
import com.visoport.medicine.R;
/**
* 适配器
*/
public class RadioAdapter extends BaseAdapter {
private LayoutInflater inflater;
private String[] areas;
private viewHolder holder;
// 标记用户当前选择那个地区
private int index = -1;
private Context c;
private OnItemSelectedListener listener;
public interface OnItemSelectedListener{
void onItemClickListener(int position);
}
public void setOnItemSelectedLstenerner(OnItemSelectedListener listener) {
this.listener = listener;
}
public RadioAdapter(Context c, String[] areas) {
super();
this.c = c;
this.areas = areas;
inflater = LayoutInflater.from(c);
}
@Override
public int getCount() {
return areas.length;
}
@Override
public Object getItem(int position) {
return null;
}
@Override
public long getItemId(int position) {
return 0;
}
@Override
public View getView(final int position, View convertView, ViewGroup parent) {
holder = new viewHolder();
if (convertView == null) {
convertView = inflater.inflate(R.layout.item_radiobutton,null);
holder.nameTxt = (TextView) convertView.findViewById(R.id.tv_country_and_area);
holder.selectBtn = (RadioButton) convertView.findViewById(R.id.radio);
convertView.setTag(holder);
} else {
holder = (viewHolder) convertView.getTag();
}
holder.nameTxt.setText(areas[position]);
holder.selectBtn
.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
if (isChecked) {
Toast.makeText(c, "您选择的地区是:" + areas[position], Toast.LENGTH_LONG).show();
if (listener != null) {
listener.onItemClickListener(position);
}
index = position;
notifyDataSetChanged();
}
}
});
if (index == position) {// 选中的条目和当前的条目是否相等
holder.selectBtn.setChecked(true);
} else {
holder.selectBtn.setChecked(false);
}
return convertView;
}
public class viewHolder {
public TextView nameTxt;
public RadioButton selectBtn;
}
}
- 需要写回调方法 void onItemClickListener(int position);
private OnItemSelectedListener listener;
public interface OnItemSelectedListener{
void onItemClickListener(int position);
}
public void setOnItemSelectedLstenerner(OnItemSelectedListener listener) {
this.listener = listener;
}
holder.selectBtn
.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
if (isChecked) {
Toast.makeText(c, "您:" + areas[position], Toast.LENGTH_LONG).show();
if (listener != null) {
listener.onItemClickListener(position);
}
index = position;
notifyDataSetChanged();
}
}
});
4、主Activity调用
package com.visoport.medicine;
import android.os.Bundle;
import android.os.Message;
import android.support.annotation.Nullable;
import android.support.v7.widget.Toolbar;
import android.widget.ListView;
import android.widget.RadioGroup;
import android.widget.TextView;
import com.visoport.medicine.ui.activity.activity.base.BaseActivity;
import com.visoport.medicine.ui.activity.adapter.RadioAdapter;
/**
* 国家与地区
*/
public class CounrtyAreaActivity extends BaseActivity {
private ListView radioButtonList;
private RadioAdapter adapter;
private String[] areas = {"香港", "澳门", "台湾", "中国大陆", "新加坡",
"马来西亚", "美国", "日本"};
private TextView tv_country_area_name;
private RadioGroup rg_area;
// private Button btn_ok;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.item_courty_area);
Toolbar toolbar=initToolBar(true,"国家与地区");
toolbar.setNavigationIcon(R.drawable.ic_back);
radioButtonList = (ListView) findViewById(R.id.list);
tv_country_area_name = (TextView) findViewById(R.id.tv_country_area_name);
rg_area= (RadioGroup) findViewById(R.id.rg_area);
adapter = new RadioAdapter(this, areas);
radioButtonList.setAdapter(adapter);
adapter.notifyDataSetChanged();
//回调
adapter.setOnItemSelectedLstenerner(new RadioAdapter.OnItemSelectedListener() {
@Override
public void onItemClickListener(int position) {
tv_country_area_name.setText(areas[position]);
}
});
}
@Override
protected void handler(Message msg) {
}
@Override
protected void initContentView(Bundle savedInstanceState) {
}
}
我这里用的是listview,大家也可以用RecycleView去尝试都不难!
效果图如下
补充说明:
点击RadioButton背景切换
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_checked="true" android:drawable="@drawable/ic_checked"/>
<item android:state_checked="false" android:drawable="@drawable/ic_uncheck"/>
<item android:drawable="@drawable/ic_uncheck"/>
</selector>
主布局
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<include
android:id="@+id/head_title_menu"
layout="@layout/custome_toolbar"/>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="10dp"
android:orientation="horizontal">
<TextView
android:layout_width="0dp"
android:layout_height="wrap_content"
android:gravity="center"
android:layout_weight="1"
android:text="当前选择国家:"
android:textSize="16sp" />
<TextView
android:id="@+id/tv_country_area_name"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:text="香港"
android:layout_weight="1"
android:textSize="16sp" />
</LinearLayout>
<ListView
android:id="@+id/list"
android:layout_width="match_parent"
android:layout_height="480dp"
android:layout_marginTop="10dp"
android:scrollbars="none" />
</LinearLayout>
转载请注明出处!http://blog.csdn.net/qq_15950325/article/details/70260652这里那个recycleview需要源码的可以直接在博客左边加群或者加我QQ1040271995欢迎大家批评指导!
[置顶] Android RadioButton与TextView浪漫约会?的更多相关文章
- [置顶] Android开发笔记(成长轨迹)
分类: 开发学习笔记2013-06-21 09:44 26043人阅读 评论(5) 收藏 Android开发笔记 1.控制台输出:called unimplemented OpenGL ES API ...
- [置顶] Android事件—单选按键和下拉按键
在平常的开发中单选按键和下拉按键是非常常用的2个点击事件.首先介绍下单选按键 1:单选按键,单选的主键是radiogroup 这个主键也是很重要的 首先介绍下主键的布局 <?xml versio ...
- [置顶] Android应用开发之版本更新你莫愁
传送门 ☞ 轮子的专栏 ☞ 转载请注明 ☞ http://blog.csdn.net/leverage_1229 今天我们学习如何实现Android应用的自动更新版本功能,这是在各种语言编写的应用中都 ...
- [置顶] Android布局管理器 - 详细解析布局实现
布局管理器都是以ViewGroup为基类派生出来的; 使用布局管理器可以适配不同手机屏幕的分辨率,尺寸大小; 布局管理器之间的继承关系 : 在上面的UML图中可以看出, 绝对布局 帧布局 网格布局 相 ...
- [置顶]
Android Shape一些新玩法?
敏少咨讯: 1.生活琐事篇 最近由于公司赶项目所以偷懒了,博客没有及时更新,还请小伙伴们手下留情啊!最近发生了很多趣事,就在今天我们学校退书籍费,这可把我开心的哈哈!无缘无故又有钱了,嘿嘿,刚好五一出 ...
- [置顶]
Android 关于BottomDialogSheet 与Layout擦出爱的火花?
今天上班做那个类似于ios拍照的那种效果图 就是个垂直布局然后里面textview+分割线+textview+button 当然也可以用button+分割线+button 方法有很多,选择适合自己的就 ...
- [置顶] Android EditText/TextView使用SpannableString显示复合文本
在Android中EditText用于编辑文本,TextView用于显示文本,但是有时候我们需要对其中的文本进行样式等方面的设置.Android为我们提供了SpannableString类来对指定文本 ...
- [置顶] android 自定义TextView
系统自带的控件TextView有时候没满一行就换行了,为了解决这个问题,自定义了一个TextView,只有一行显示不完全的情况下才会去换行显示,代码如下: package com.open.textv ...
- [置顶]
Android 适配真要命?
原始尺寸场景 相信大家对上面也有所有耳闻另外就是如何计算屏幕的密度一般都是按照勾股定理例如中等屏幕密度 480^2+800^2开根号 然后除以当前屏幕尺寸3.5-4.2之间尺寸. 对于刚出来的那些An ...
随机推荐
- curl简介、安装及使用
目录 curl简介 curl安装 curl使用 curl简介 curl是Linux下一个强大的文件传输工具,它利用URL语法在命令行方式下工作,支持文件上传和下载. curl安装 Ubuntu系统键入 ...
- 数据结构&算法(一)_堆、栈(堆栈)、队列、链表
堆: ①堆通常是一个可以被看做一棵树的数组对象.堆总是满足下列性质: ·堆中某个节点的值总是不大于或不小于其父节点的值: ·堆总是一棵完全二叉树.将根节点最大的堆叫做最大堆或大根堆,根节点最小的堆叫做 ...
- 转:MVC遇上bootstrap后的ajax表单验证
使用bootstrap后他由他自带的样式has-error,想要使用它就会比较麻烦,往常使用jqueyr.validate的话只有使用他自己的样式了,而且有模型在使用模型验证更方便点.怎么解决呢? 当 ...
- iOS 自定义滑动切换TabbarItem 觉得设计丑也要做出来的UI效果。。。
UI丑却要继续做的感言: 对UI不满意的时候,就会觉得丑爆了,时间长了,却丑习惯了. 论前一阵子Tabbar 多丑,丑得最后不要tabbar了...但是自定义tabbar 和遇到的问题解决的过程可以记 ...
- HDU2385Stock
/*既然前一天的可以省下来给过后一天卖,那么就倒着卖,那么最后一天的只能在最后一天卖,如果可以卖完,还有可卖的名额,那么就从 倒数第二天取,如果卖不完只能丢掉,而且必定是尽量留到价格最高的那一天卖*/ ...
- How to create a notification with NotificationCompat.Builder?AAAA
Ask Question up vote 49 down vote favorite 19 I need to create a simple notification which will be s ...
- winform webbrowser禁用网页target=blank
/// <summary> /// 屏蔽target=_blank 的弹出窗口 /// </summary> /// <param name="sender&q ...
- BZOJ-5424: 烧桥计划(单调队列)
BZOJ-5424: 烧桥计划(单调队列) 题目链接 题解: 先考虑最暴力的\(dp\):设\(f[k][i]\)表示搞掉第\(1\sim i\)段,烧了\(k\)段的最小花费,设\(calc(x,y ...
- Python中求阶乘(factorial)
1. math.factorial(x) import math value = math.factorial(x) 2. reduce函数 def factorial(n): return redu ...
- LeetCode Weekly Contest 23
LeetCode Weekly Contest 23 1. Reverse String II Given a string and an integer k, you need to reverse ...