• Android记录4--自定义ToggleButton+用SharedPreferences保存用户配置


    Android记录4--自定义ToggleButton+用SharedPreferences保存用户配置

    2013年8月14日Android记录

    很多应用都会有用户设置,用户的一些偏好可以由用户来决定那是应用人性化的体现,在实际开发中很多情况都作成可配置的了,本篇博客要介绍的是一个比较炫的状态按钮切换,我想很多开发者都想做出这样的效果,在这里我也就把自己参与的项目当中的这部分实现,做出Demo来于朋友们分享。

    没有图,我感觉就特别不舒服:
     
     


    这样看没办法看出效果,如果能做出动态图就好了,下次吧。

    除了ToggleButton的自定义之外,用户配置的信息也是要保存起来的,每一次启动程序的时候要能保证使用的是之前的配置,而不是默认配置,在这里使用SharedPreferences是最好的选择了。

    想要源码的猛戳这里:http://download.csdn.net/detail/wwj_748/5945829


    布局文件:
    /2013.08.14_ToggleButton_demo/res/layout/settings.xml
    <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>


    哪些selector文件的代码就不贴了,自己看源码吧


    Activity文件
    /2013.08.14_ToggleButton_demo/src/com/wwj/toggle/Setting.java
    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);
    	}
    
    }
    

    工具类:
    /2013.08.14_ToggleButton_demo/src/com/wwj/toggle/SettingUtils.java
    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();	//提交
    	}
    }
    

    /2013.08.14_ToggleButton_demo/src/com/wwj/toggle/DisplayUtils.java
    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;
    	}
    }
    


    /2013.08.14_ToggleButton_demo/src/com/wwj/toggle/ToggleListener.java
    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);
    		}
    	}
    
    }
    



  • 相关阅读:
    打印杨辉三角(直角) 练习
    数组 for 练习
    数组排序 (转)
    java如何获取从键盘输入多个数字,并计算平均数 (转)
    Eclipse快捷键 (转) 待续
    输入首字母判断周几(有瑕疵) 练习
    在java中如何用键盘输入一个数,字符,字符串 (转)
    Java中获取键盘输入值的三种方法 (转)
    Java 位运算(移位、位与、或、异或、非) (转)
    3.4 编程式路由
  • 原文地址:https://www.cnblogs.com/riskyer/p/3257970.html
Copyright © 2020-2023  润新知