toggbutton详解手机开发
2023-06-13 09:20:13 时间
很多应用都会有用户设置,用户的一些偏好可以由用户来决定那是应用人性化的体现,在实际开发中很多情况都作成可配置的了,本篇博客要介绍的是一个比较炫的状态按钮切换,我想很多开发者都想做出这样的效果,在这里我也就把自己参与的项目当中的这部分实现,做出Demo来于朋友们分享。
除了ToggleButton的自定义之外,用户配置的信息也是要保存起来的,每一次启动程序的时候要能保证使用的是之前的配置,而不是默认配置,在这里使用SharedPreferences是最好的选择了。
[html]
view plain
copy
print
?
![在CODE上查看代码片](http://blog.ytso.com/zb_users/plugin/LazyLoad/usr/loading.gif)
LinearLayout xmlns:android= http://schemas.android.com/apk/res/android
android:id= @+id/LinearLayout1
android:layout_width= match_parent
android:layout_height= match_parent
android:background= @drawable/bg
android:orientation= vertical
RelativeLayout
android:layout_width= match_parent
android:layout_height= wrap_content
android:background= @drawable/banner_bg
TextView
android:id= @+id/tv_Title
android:layout_width= wrap_content
android:layout_height= 42dp
android:layout_centerHorizontal= true
android:gravity= center
android:text= 设置
android:textColor= #ffffff
android:textSize= 22sp /
/RelativeLayout
ScrollView
android:layout_width= match_parent
android:layout_height= match_parent
LinearLayout
android:layout_width= match_parent
android:layout_height= wrap_content
android:orientation= vertical
LinearLayout
android:id= @+id/layout_AutoPlay
android:layout_width= match_parent
android:layout_height= wrap_content
android:background= @drawable/item_short_bg_selector
android:gravity= center_vertical
TextView
android:id= @+id/tv_AutoPlay
android:layout_width= 0dp
android:layout_height= wrap_content
android:layout_marginLeft= 10dp
android:layout_weight= 1
android:focusable= false
android:singleLine= true
android:text= 自动播放
android:textColor= #7a6f66
android:textSize= 18sp /
RelativeLayout
android:layout_width= wrap_content
android:layout_height= wrap_content
android:layout_marginRight= 10dp
ToggleButton
android:id= @+id/toggle_AutoPlay
android:layout_width= wrap_content
android:layout_height= wrap_content
android:background= @drawable/toggle_selector
android:gravity= left|center_vertical
android:paddingLeft= 14dp
android:paddingRight= 14dp
android:textColor= #ffffff
android:textOff= OFF
android:textOn= ON /
ImageButton
android:id= @+id/toggleButton_AutoPlay
android:layout_width= wrap_content
android:layout_height= wrap_content
android:layout_alignRight= @+id/toggle_AutoPlay
android:background= #00000000
android:src= @drawable/progress_thumb_selector /
/RelativeLayout
/LinearLayout
ImageView
android:layout_width= match_parent
android:layout_height= wrap_content
android:scaleType= fitXY
android:src= @drawable/list_divider /
LinearLayout
android:id= @+id/layout_StartOnBoot
android:layout_width= match_parent
android:layout_height= wrap_content
android:background= @drawable/item_short_bg_selector
android:gravity= center_vertical
TextView
android:id= @+id/tv_StartOnBoot
android:layout_width= 0dp
android:layout_height= wrap_content
android:layout_marginLeft= 10dp
android:layout_weight= 1
android:focusable= false
android:singleLine= true
android:text= 开机自启动
android:textColor= #7a6f66
android:textSize= 18sp /
RelativeLayout
android:layout_width= wrap_content
android:layout_height= wrap_content
android:layout_marginRight= 10dp
ToggleButton
android:id= @+id/toggle_StartOnBoot
android:layout_width= wrap_content
android:layout_height= wrap_content
android:background= @drawable/toggle_selector
android:gravity= left|center_vertical
android:paddingLeft= 14dp
android:paddingRight= 14dp
android:textColor= #ffffff
android:textOff= OFF
android:textOn= ON /
ImageButton
android:id= @+id/toggleButton_StartOnBoot
android:layout_width= wrap_content
android:layout_height= wrap_content
android:layout_alignRight= @+id/toggle_StartOnBoot
android:background= #00000000
android:src= @drawable/progress_thumb_selector /
/RelativeLayout
/LinearLayout
/LinearLayout
/ScrollView
/LinearLayout
[java]
view plain
copy
print
?
![在CODE上查看代码片](http://blog.ytso.com/zb_users/plugin/LazyLoad/usr/loading.gif)
package com.wwj.toggle;
import android.app.Activity;
import android.os.Bundle;
import android.view.Gravity;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.ImageButton;
import android.widget.LinearLayout;
import android.widget.RelativeLayout;
import android.widget.ToggleButton;
/**
* 自定义ToggleButton的例子
*
* @author wwj 2013年8月14
*/
public class Setting extends Activity {
private LinearLayout layout_AutoPlay;
private LinearLayout layout_StartOnBoot;
private ToggleButton toggle_AutoPlay;
private ToggleButton toggle_StartOnBoot;
private ImageButton toggleButton_AutoPlay;
private ImageButton toggleButton_StartOnBoot;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.settings);
// 找到控件
layout_AutoPlay = (LinearLayout) findViewById(R.id.layout_AutoPlay);
layout_StartOnBoot = (LinearLayout) findViewById(R.id.layout_StartOnBoot);
toggle_AutoPlay = (ToggleButton) findViewById(R.id.toggle_AutoPlay);
toggle_StartOnBoot = (ToggleButton) findViewById(R.id.toggle_StartOnBoot);
toggleButton_AutoPlay = (ImageButton) findViewById(R.id.toggleButton_AutoPlay);
toggleButton_StartOnBoot = (ImageButton) findViewById(R.id.toggleButton_StartOnBoot);
initViews();
setListeners();
}
private void initViews() {
// 是否自动播放,获取SharePerference保存的用户配置
boolean isAutoPlay = SettingUtils.get(this, SettingUtils.AUTO_PLAY,
false);
toggle_AutoPlay.setChecked(isAutoPlay);
RelativeLayout.LayoutParams params = (RelativeLayout.LayoutParams) toggleButton_AutoPlay
.getLayoutParams();
if (isAutoPlay) { // 如果是自动播放
// 调整位置
params.addRule(RelativeLayout.ALIGN_RIGHT, 1);
params.addRule(RelativeLayout.ALIGN_LEFT,
R.id.toggleButton_AutoPlay);
toggleButton_AutoPlay.setLayoutParams(params);
toggleButton_AutoPlay
.setImageResource(R.drawable.progress_thumb_selector);
toggle_AutoPlay.setGravity(Gravity.RIGHT | Gravity.CENTER_VERTICAL);
} else {
// 调整位置
params.addRule(RelativeLayout.ALIGN_RIGHT, R.id.toggle_AutoPlay);
params.addRule(RelativeLayout.ALIGN_LEFT, 1);
toggleButton_AutoPlay.setLayoutParams(params);
toggleButton_AutoPlay
.setImageResource(R.drawable.progress_thumb_off_selector);
toggle_AutoPlay.setGravity(Gravity.LEFT | Gravity.CENTER_VERTICAL);
}
boolean isAutostart = SettingUtils.get(this,
SettingUtils.IS_AUTO_START, true);
toggle_StartOnBoot.setChecked(isAutostart);
RelativeLayout.LayoutParams params3 = (RelativeLayout.LayoutParams) toggleButton_StartOnBoot
.getLayoutParams();
if (isAutostart) {
// 调整位置
params3.addRule(RelativeLayout.ALIGN_RIGHT, 1);
params3.addRule(RelativeLayout.ALIGN_LEFT, R.id.toggle_StartOnBoot);
toggleButton_StartOnBoot.setLayoutParams(params3);
toggleButton_StartOnBoot
.setImageResource(R.drawable.progress_thumb_selector);
toggle_StartOnBoot.setGravity(Gravity.RIGHT
| Gravity.CENTER_VERTICAL);
} else {
// 调整位置
params3.addRule(RelativeLayout.ALIGN_RIGHT, R.id.toggle_StartOnBoot);
params3.addRule(RelativeLayout.ALIGN_LEFT, 1);
toggleButton_StartOnBoot.setLayoutParams(params3);
toggleButton_StartOnBoot
.setImageResource(R.drawable.progress_thumb_off_selector);
toggle_StartOnBoot.setGravity(Gravity.LEFT
| Gravity.CENTER_VERTICAL);
}
}
private void setListeners() {
toggle_AutoPlay.setOnCheckedChangeListener(new ToggleListener(this,
自动播放 , toggle_AutoPlay, toggleButton_AutoPlay));
toggle_StartOnBoot.setOnCheckedChangeListener(new ToggleListener(this,
开机自启动 , toggle_StartOnBoot, toggleButton_StartOnBoot));
// UI事件,按钮点击事件
OnClickListener clickToToggleListener = new OnClickListener() {
@Override
public void onClick(View v) {
toggle_AutoPlay.toggle();
}
};
toggleButton_AutoPlay.setOnClickListener(clickToToggleListener);
layout_AutoPlay.setOnClickListener(clickToToggleListener);
// UI事件,按钮点击事件
OnClickListener clickToToggleAutostartListener = new OnClickListener() {
public void onClick(View v) {
toggle_StartOnBoot.toggle();
}
};
toggleButton_StartOnBoot
.setOnClickListener(clickToToggleAutostartListener);
layout_StartOnBoot
.setOnClickListener(clickToToggleAutostartListener);
}
}
[java]
view plain
copy
print
?
![在CODE上查看代码片](http://blog.ytso.com/zb_users/plugin/LazyLoad/usr/loading.gif)
package com.wwj.toggle;
import android.content.Context;
import android.content.SharedPreferences;
import android.content.SharedPreferences.Editor;
import android.preference.PreferenceManager;
public class SettingUtils {
public static final String AUTO_PLAY = auto_play ; // 自动播放
public static final String IS_AUTO_START = is_auto_start ; // 开机自启动
/**
* 获取配置
* @param context
* @param name
* @param defaultValue
* @return
*/
public static boolean get(Context context, String name, boolean defaultValue) {
final SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(context);
boolean value = prefs.getBoolean(name, defaultValue);
return value;
}
/**
* 保存用户配置
* @param context
* @param name
* @param value
* @return
*/
public static boolean set(Context context, String name, boolean value) {
final SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(context);
Editor editor = prefs.edit();
editor.putBoolean(name, value);
return editor.commit(); //提交
}
}
[java]
view plain
copy
print
?
![在CODE上查看代码片](http://blog.ytso.com/zb_users/plugin/LazyLoad/usr/loading.gif)
package com.wwj.toggle;
import android.content.Context;
public class DisplayUtils {
public static int dip2px(Context context, float dpValue) {
final float scale = context.getResources().getDisplayMetrics().density;
return (int) (dpValue * scale + 0.5f);
}
public static int px2dip(Context context, float pxValue) {
final float scale = context.getResources().getDisplayMetrics().density;
return (int) (pxValue / scale + 0.5f);
}
public static int getScreenWidth(Context context) {
return context.getResources().getDisplayMetrics().widthPixels;
}
public static int getScreenHeight(Context context) {
return context.getResources().getDisplayMetrics().heightPixels;
}
}
[java]
view plain
copy
print
?
![在CODE上查看代码片](http://blog.ytso.com/zb_users/plugin/LazyLoad/usr/loading.gif)
package com.wwj.toggle;
import android.content.Context;
import android.view.Gravity;
import android.view.animation.TranslateAnimation;
import android.widget.CompoundButton;
import android.widget.CompoundButton.OnCheckedChangeListener;
import android.widget.ImageButton;
import android.widget.RelativeLayout;
import android.widget.ToggleButton;
/**
* 状态按钮的监听事件
*
* @author wwj
*
*/
public class ToggleListener implements OnCheckedChangeListener {
private Context context;
private String settingName;
private ToggleButton toggle;
private ImageButton toggle_Button;
public ToggleListener(Context context, String settingName,
ToggleButton toggle, ImageButton toggle_Button) {
this.context = context;
this.settingName = settingName;
this.toggle = toggle;
this.toggle_Button = toggle_Button;
}
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
// 保存设置
if ( 自动播放 .equals(settingName)) {
SettingUtils.set(context, SettingUtils.AUTO_PLAY, isChecked);
} else if ( 开机自启动 .equals(settingName)) {
SettingUtils.set(context, SettingUtils.IS_AUTO_START, isChecked);
}
// 播放动画
RelativeLayout.LayoutParams params = (RelativeLayout.LayoutParams) toggle_Button
.getLayoutParams();
if (isChecked) {
// 调整位置
params.addRule(RelativeLayout.ALIGN_RIGHT, 1);
if ( 自动播放 .equals(settingName)) {
params.addRule(RelativeLayout.ALIGN_LEFT, R.id.toggle_AutoPlay);
} else if ( 开机自启动 .equals(settingName)) {
params.addRule(RelativeLayout.ALIGN_LEFT,
R.id.toggle_StartOnBoot);
}
toggle_Button.setLayoutParams(params);
toggle_Button.setImageResource(R.drawable.progress_thumb_selector);
toggle.setGravity(Gravity.RIGHT | Gravity.CENTER_VERTICAL);
// 播放动画
TranslateAnimation animation = new TranslateAnimation(
DisplayUtils.dip2px(context, 40), 0, 0, 0);
animation.setDuration(200);
toggle_Button.startAnimation(animation);
} else {
// 调整位置
if ( 自动播放 .equals(settingName)) {
params.addRule(RelativeLayout.ALIGN_RIGHT, R.id.toggle_AutoPlay);
} else if ( 开机自启动 .equals(settingName)) {
params.addRule(RelativeLayout.ALIGN_RIGHT,
R.id.toggle_StartOnBoot);
}
params.addRule(RelativeLayout.ALIGN_LEFT, 1);
toggle_Button.setLayoutParams(params);
toggle_Button
.setImageResource(R.drawable.progress_thumb_off_selector);
toggle.setGravity(Gravity.LEFT | Gravity.CENTER_VERTICAL);
// 播放动画
TranslateAnimation animation = new TranslateAnimation(
DisplayUtils.dip2px(context, 40), 0, 0, 0);
animation.setDuration(200);
toggle_Button.startAnimation(animation);
}
}
}
除了ToggleButton的自定义之外,用户配置的信息也是要保存起来的,每一次启动程序的时候要能保证使用的是之前的配置,而不是默认配置,在这里使用SharedPreferences是最好的选择了。
[html]
view plain
copy
?
![在CODE上查看代码片](http://blog.ytso.com/zb_users/plugin/LazyLoad/usr/loading.gif)
![派生到我的代码片](http://blog.ytso.com/zb_users/plugin/LazyLoad/usr/loading.gif)
[java]
view plain
copy
?
![在CODE上查看代码片](http://blog.ytso.com/zb_users/plugin/LazyLoad/usr/loading.gif)
![派生到我的代码片](http://blog.ytso.com/zb_users/plugin/LazyLoad/usr/loading.gif)
工具类: /2013.08.14_ToggleButton_demo/src/com/wwj/toggle/SettingUtils.java
[java]
view plain
copy
?
![在CODE上查看代码片](http://blog.ytso.com/zb_users/plugin/LazyLoad/usr/loading.gif)
![派生到我的代码片](http://blog.ytso.com/zb_users/plugin/LazyLoad/usr/loading.gif)
/2013.08.14_ToggleButton_demo/src/com/wwj/toggle/DisplayUtils.java
[java]
view plain
copy
?
![在CODE上查看代码片](http://blog.ytso.com/zb_users/plugin/LazyLoad/usr/loading.gif)
![派生到我的代码片](http://blog.ytso.com/zb_users/plugin/LazyLoad/usr/loading.gif)
[java]
view plain
copy
?
![在CODE上查看代码片](http://blog.ytso.com/zb_users/plugin/LazyLoad/usr/loading.gif)
![派生到我的代码片](http://blog.ytso.com/zb_users/plugin/LazyLoad/usr/loading.gif)
相关文章
- ListView的 多个addHeaderView详解手机开发
- FragmentPagerAdapter刷新数据原理分析与解决详解手机开发
- 利用UIWebView显示gif详解手机开发
- ios怎么判断日期是周末详解手机开发
- 微信企业号开发:企业支付openid的获取 appid and openid not match详解手机开发
- iOS开发笔记 – 用CocoaPods管理第三方库详解手机开发
- [android] 天气app布局练习(二)详解手机开发
- [android] 在不同的activity之间传递数据详解手机开发
- [android] 短信发送器详解手机开发
- 语音兰度短信详解手机开发
- 文件图片上传详解手机开发
- 使用LRU算法缓存图片,android 3.0详解手机开发
- Android开发之Path详解手机开发
- android VPN编程详解手机开发
- 2017年校园招聘ios面试题详解手机开发
- iOS-语言本地化详解手机开发
- Kotlin新增协程、类型别名特性,提升了对JavaScript的支持详解手机开发
- webview页面的activity点击返回按钮详解手机开发
- Android Context.getSystemService() 与 ServiceManager 的理解和使用详解手机开发