1.简介
GitHub地址:https://github.com/zcweng/SwitchButton
gradle:
repositories { mavenCentral() jcenter() } ... dependencies { compile 'com.github.zcweng:switch-button:0.0.3@aar' }
2.使用
xml中使用:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" xmlns:app="http://schemas.android.com/apk/res-auto" android:orientation="vertical"> <com.suke.widget.SwitchButton android:id="@+id/switch_button" android:layout_width="wrap_content" android:layout_height="wrap_content"/> </LinearLayout>
activity.java:
com.suke.widget.SwitchButton switchButton = (com.suke.widget.SwitchButton) findViewById(R.id.switch_button); switchButton.setChecked(true); switchButton.isChecked(); switchButton.toggle(); //switch state switchButton.toggle(false);//switch without animation switchButton.setShadowEffect(true);//disable shadow effect switchButton.setEnabled(false);//disable button switchButton.setEnableEffect(false);//disable the switch animation switchButton.setOnCheckedChangeListener(new SwitchButton.OnCheckedChangeListener() { @Override public void onCheckedChanged(SwitchButton view, boolean isChecked) { //TODO do your job } });
more style:
<attr name="sb_shadow_radius" format="reference|dimension"/> 阴影半径 <attr name="sb_shadow_offset" format="reference|dimension"/> 阴影偏移 <attr name="sb_shadow_color" format="reference|color"/> 阴影颜色 <attr name="sb_uncheck_color" format="reference|color"/> 关闭颜色 <attr name="sb_checked_color" format="reference|color"/> 开启颜色 <attr name="sb_border_width" format="reference|dimension"/> 边框宽度 <attr name="sb_checkline_color" format="reference|color"/> 开启指示器颜色 <attr name="sb_checkline_width" format="reference|dimension"/> 开启指示器线宽 <attr name="sb_uncheckcircle_color" format="reference|color"/> 关闭指示器颜色 <attr name="sb_uncheckcircle_width" format="reference|dimension"/> 关闭指示器线宽 <attr name="sb_uncheckcircle_radius" format="reference|dimension"/>关闭指示器半径 <attr name="sb_checked" format="reference|boolean"/> 是否选中 <attr name="sb_shadow_effect" format="reference|boolean"/> 是否启用阴影 <attr name="sb_effect_duration" format="reference|integer"/> 动画时间,默认300ms <attr name="sb_button_color" format="reference|color"/> 按钮颜色 <attr name="sb_show_indicator" format="reference|boolean"/> 是否显示指示器,默认true:显示 <attr name="sb_background" format="reference|color"/> 背景色,默认白色 <attr name="sb_enable_effect" format="reference|boolean"/> 是否启用特效,默认true
也可以直接把SwitchButton.java和switch_btton_attr.xml复制到项目中直接使用
<com.example.switchbuttondemo1.customview.SwitchButton android:layout_width="100dp" android:layout_height="50dp" android:id="@+id/switchbutton" android:layout_centerInParent="true" app:sb_shadow_color="#f00" app:sb_uncheck_color="#0f0" app:sb_checked_color="#f0f" app:sb_border_width="3dp" app:sb_checkline_color="#f00" app:sb_checkline_width="5dp" app:sb_uncheckcircle_color="#f00" app:sb_uncheckcircle_radius="10dp" app:sb_uncheckcircle_width="2dp" app:sb_button_color="#0ff" app:sb_show_indicator="false" />