ToggleButton有两种状态:选中和未选中,可以为不同的状态设置不同的文本
android:checked=”false” 设置按钮未选中
android:textOff=”暗” 未选中状态显示的文字
android:textOn=”亮” 选中状态显示的文字
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical">
<ToggleButton android:id="@+id/toggleButton" android:layout_width="match_parent" android:layout_height="wrap_content" android:checked="false" android:textOff="暗" android:textOn="亮" />
<ImageView android:id="@+id/imageView" android:layout_width="match_parent" android:layout_height="match_parent" android:background="@android:color/black" />
</LinearLayout>
public class MainActivity extends AppCompatActivity {
private ToggleButton toggleButton;
private ImageView imageView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
toggleButton = findViewById(R.id.toggleButton);
imageView = findViewById(R.id.imageView);
//给当前的toggleButton设置监听器
toggleButton.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
/** * 当toggleButton被点击的时候,onCheckedChanged方法会执 * 通过点击toggleButton切换imageView的黑白色 * @param buttonView 代表被点击的控件本身 * @param sChecked 代表被点击的控件的状态 */
switch (buttonView.getId()) {
case R.id.toggleButton:
imageView.setBackgroundColor(isChecked ? Color.WHITE : Color.BLACK);
break;
default:
}
}
});
}
}