Android自定义RadioGroup实现单选完整示例

简介:

MainActivity如下:

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. package cc.testradiogroup;  
  2.   
  3. import android.os.Bundle;  
  4. import android.widget.RadioButton;  
  5. import android.widget.RadioGroup;  
  6. import android.widget.RadioGroup.OnCheckedChangeListener;  
  7. import android.app.Activity;  
  8. /** 
  9.  * Demo描述: 
  10.  * 利用自定义RadioGroup实现单选 
  11.  * 
  12.  * 参考资料: 
  13.  * 1 http://blog.csdn.net/xiaanming 
  14.  * 2 http://bbs.51cto.com/thread-954128-1.html 
  15.  *  
  16.  *   Thank you very much 
  17.  */  
  18. public class MainActivity extends Activity {  
  19.     private RadioGroup mRadioGroup;   
  20.     @Override  
  21.     protected void onCreate(Bundle savedInstanceState) {  
  22.         super.onCreate(savedInstanceState);  
  23.         setContentView(R.layout.main);  
  24.         init();  
  25.     }  
  26.     
  27.     private void init(){  
  28.         mRadioGroup=(RadioGroup) findViewById(R.id.radioGroup);  
  29.         mRadioGroup.setOnCheckedChangeListener(new RadioButtonOnCheckedChangeListenerImpl());  
  30.     }  
  31.       
  32.     // 监听单选的变化  
  33.     private class RadioButtonOnCheckedChangeListenerImpl implements OnCheckedChangeListener {  
  34.         @Override  
  35.         public void onCheckedChanged(RadioGroup group, int checkedId) {  
  36.             RadioButton rb = (RadioButton) findViewById(group.getCheckedRadioButtonId());  
  37.             String currentSelected = rb.getText().toString();  
  38.             System.out.println("现在选中是:" + currentSelected);  
  39.         }  
  40.     }  
  41.   
  42. }  


main.xml如下:

[html]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <!-- 步骤如下: -->  
  3. <!--1: android:button="@null" 去掉自带的图标   -->  
  4. <!--2:android:drawableRight="@drawable/line" 在文字的右边设置图片-->  
  5. <!--3: android:drawablePadding="10dip" 图片与文字间的距离-->  
  6. <!--4:android:layout_marginLeft="-17dip" 每个RadioButton距离左边缘或者距其左RadioButton的距离-->  
  7. <LinearLayout   
  8.     xmlns:android="http://schemas.android.com/apk/res/android"  
  9.     android:layout_width="fill_parent"  
  10.     android:layout_height="fill_parent"  
  11.     android:orientation="vertical"  
  12.     android:gravity="center_horizontal" >  
  13.   
  14.     <TextView  
  15.         android:layout_width="wrap_content"  
  16.         android:layout_height="wrap_content"  
  17.         android:textSize="15sp"  
  18.         android:text="测试自定义的RadioGroup来实现单选功能" >  
  19.     </TextView>  
  20.   
  21.     <RadioGroup  
  22.         android:id="@+id/radioGroup"  
  23.         android:layout_width="wrap_content"  
  24.         android:layout_height="wrap_content"  
  25.         android:orientation="horizontal"  
  26.         android:background="@drawable/bg" >  
  27.   
  28.         <RadioButton  
  29.             android:id="@+id/cai"  
  30.             android:layout_width="wrap_content"  
  31.             android:layout_height="wrap_content"  
  32.             android:layout_marginLeft="-17dip"  
  33.             android:checked="true"  
  34.             android:button="@null"  
  35.             android:drawableRight="@drawable/line"  
  36.             android:drawablePadding="10dip"  
  37.             android:text="菜"  
  38.             android:textColor="@drawable/text_selector" >  
  39.         </RadioButton>  
  40.   
  41.         <RadioButton  
  42.             android:id="@+id/tang"  
  43.             android:layout_width="wrap_content"  
  44.             android:layout_height="wrap_content"  
  45.              android:layout_marginLeft="-15dip"  
  46.             android:button="@null"  
  47.             android:drawableRight="@drawable/line"  
  48.             android:drawablePadding="10dip"  
  49.             android:text="汤"   
  50.             android:textColor="@drawable/text_selector">  
  51.         </RadioButton>  
  52.           
  53.         <RadioButton  
  54.             android:id="@+id/zhushi"  
  55.             android:layout_width="wrap_content"  
  56.             android:layout_height="wrap_content"  
  57.              android:layout_marginLeft="-15dip"  
  58.             android:button="@null"  
  59.             android:drawableRight="@drawable/line"  
  60.             android:drawablePadding="10dip"  
  61.             android:text="主   食"  
  62.             android:textColor="@drawable/text_selector" >  
  63.         </RadioButton>  
  64.           
  65.         <RadioButton  
  66.             android:id="@+id/zhou"  
  67.             android:layout_width="wrap_content"  
  68.             android:layout_height="wrap_content"  
  69.              android:layout_marginLeft="-15dip"  
  70.             android:button="@null"  
  71.             android:drawableRight="@drawable/line"  
  72.             android:drawablePadding="15dip"  
  73.             android:text="粥"  
  74.             android:textColor="@drawable/text_selector" >  
  75.         </RadioButton>  
  76.     </RadioGroup>  
  77.   
  78. </LinearLayout>  

text_selector.xml如下:

[html]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <selector xmlns:android="http://schemas.android.com/apk/res/android" >  
  3.       <item android:color="#ffffff" android:state_checked="true"/>  
  4.       <item android:color="#000000"/>  
  5. </selector>  
相关文章
|
5月前
|
Android开发 UED 计算机视觉
Android自定义view之线条等待动画(灵感来源:金铲铲之战)
本文介绍了一款受游戏“金铲铲之战”启发的Android自定义View——线条等待动画的实现过程。通过将布局分为10份,利用`onSizeChanged`测量最小长度,并借助画笔绘制动态线条,实现渐变伸缩效果。动画逻辑通过四个变量控制线条的增长与回退,最终形成流畅的等待动画。代码中详细展示了画笔初始化、线条绘制及动画更新的核心步骤,并提供完整源码供参考。此动画适用于加载场景,提升用户体验。
448 5
Android自定义view之线条等待动画(灵感来源:金铲铲之战)
|
5月前
|
Android开发
Android自定义view之利用PathEffect实现动态效果
本文介绍如何在Android自定义View中利用`PathEffect`实现动态效果。通过改变偏移量,结合`PathEffect`的子类(如`CornerPathEffect`、`DashPathEffect`、`PathDashPathEffect`等)实现路径绘制的动态变化。文章详细解析了各子类的功能与参数,并通过案例代码展示了如何使用`ComposePathEffect`组合效果,以及通过修改偏移量实现动画。最终效果为一个菱形图案沿路径运动,源码附于文末供参考。
|
5月前
|
XML Java Android开发
Android自定义view之网易云推荐歌单界面
本文详细介绍了如何通过自定义View实现网易云音乐推荐歌单界面的效果。首先,作者自定义了一个圆角图片控件`MellowImageView`,用于绘制圆角矩形图片。接着,通过将布局放入`HorizontalScrollView`中,实现了左右滑动功能,并使用`ViewFlipper`添加图片切换动画效果。文章提供了完整的代码示例,包括XML布局、动画文件和Java代码,最终展示了实现效果。此教程适合想了解自定义View和动画效果的开发者。
225 65
Android自定义view之网易云推荐歌单界面
|
5月前
|
XML 前端开发 Android开发
一篇文章带你走近Android自定义view
这是一篇关于Android自定义View的全面教程,涵盖从基础到进阶的知识点。文章首先讲解了自定义View的必要性及简单实现(如通过三个构造函数解决焦点问题),接着深入探讨Canvas绘图、自定义属性设置、动画实现等内容。还提供了具体案例,如跑马灯、折线图、太极图等。此外,文章详细解析了View绘制流程(measure、layout、draw)和事件分发机制。最后延伸至SurfaceView、GLSurfaceView、SVG动画等高级主题,并附带GitHub案例供实践。适合希望深入理解Android自定义View的开发者学习参考。
552 84
|
5月前
|
前端开发 Android开发 UED
讲讲Android为自定义view提供的SurfaceView
本文详细介绍了Android中自定义View时使用SurfaceView的必要性和实现方式。首先分析了在复杂绘制逻辑和高频界面更新场景下,传统View可能引发卡顿的问题,进而引出SurfaceView作为解决方案。文章通过Android官方Demo展示了SurfaceView的基本用法,包括实现`SurfaceHolder.Callback2`接口、与Activity生命周期绑定、子线程中使用`lockCanvas()`和`unlockCanvasAndPost()`方法完成绘图操作。
113 3
|
5月前
|
Android开发 开发者
Android自定义view之围棋动画(化繁为简)
本文介绍了Android自定义View的动画实现,通过两个案例拓展动态效果。第一个案例基于`drawArc`方法实现单次动画,借助布尔值控制动画流程。第二个案例以围棋动画为例,从简单的小球直线运动到双向变速运动,最终实现循环动画效果。代码结构清晰,逻辑简明,展示了如何化繁为简实现复杂动画,帮助读者拓展动态效果设计思路。文末提供完整源码,适合初学者和进阶开发者学习参考。
Android自定义view之围棋动画(化繁为简)
|
5月前
|
Java Android开发 开发者
Android自定义view之围棋动画
本文详细介绍了在Android中自定义View实现围棋动画的过程。从测量宽高、绘制棋盘背景,到创建固定棋子及动态棋子,最后通过属性动画实现棋子的移动效果。文章还讲解了如何通过自定义属性调整棋子和棋盘的颜色及动画时长,并优化视觉效果,如添加渐变色让白子更明显。最终效果既可作为围棋动画展示,也可用作加载等待动画。代码完整,适合进阶开发者学习参考。
104 0
|
Android开发 数据格式 XML
|
Android开发 数据格式 XML
|
14天前
|
开发工具 Android开发
X Android SDK file not found: adb.安卓开发常见问题-Android SDK 缺少 `adb`(Android Debug Bridge)-优雅草卓伊凡
X Android SDK file not found: adb.安卓开发常见问题-Android SDK 缺少 `adb`(Android Debug Bridge)-优雅草卓伊凡
187 11
X Android SDK file not found: adb.安卓开发常见问题-Android SDK 缺少 `adb`(Android Debug Bridge)-优雅草卓伊凡

热门文章

最新文章