使用ToggleButton

ToggleButton 可以实现按钮的开关效果。

它的使用方法和一般的Button 并没有什么太大的区别,在不居中多了三条常用属性

<ToggleButton
        android:id="@+id/toggleButton1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:textOn="开"
        android:textOff="关"
        android:checked="false" />

textOn 和textOff 设置按钮在两种状态下的文字,checked设置按钮当前的状态。

接下来,要想实现按钮的功能,就要在Activity中注册监听器了。注册的方法和普通Button 也基本相同,只不过实现的接口类略有不同

tButton = (ToggleButton)findViewById(R.id.toggleButton1);
		tButton.setOnCheckedChangeListener(new OnCheckedChangeListener(){
			@Override
			public void onCheckedChanged(CompoundButton buttonView,
					boolean isChecked) {
				// TODO Auto-generated method stub
				
			}
		});

注:

checked属性不设置的话默认为false

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是一个使用ToggleButton和StackPanel等控件结合DataTemplate实现自定义导航栏的例子: 1. 在WPF窗口中添加一个StackPanel控件: ```xml <StackPanel Orientation="Horizontal" VerticalAlignment="Top"> <!-- 这里将会添加ToggleButton控件 --> </StackPanel> ``` 2. 在StackPanel中添加多个ToggleButton控件,每个ToggleButton代表一个导航项,并使用DataTemplate定义ToggleButton的显示内容: ```xml <StackPanel Orientation="Horizontal" VerticalAlignment="Top"> <ToggleButton x:Name="btnPage1" ContentTemplate="{StaticResource NavigationButtonTemplate}" Command="{Binding NavigateToPage1Command}" IsChecked="{Binding IsPage1Selected}"/> <ToggleButton x:Name="btnPage2" ContentTemplate="{StaticResource NavigationButtonTemplate}" Command="{Binding NavigateToPage2Command}" IsChecked="{Binding IsPage2Selected}"/> <ToggleButton x:Name="btnPage3" ContentTemplate="{StaticResource NavigationButtonTemplate}" Command="{Binding NavigateToPage3Command}" IsChecked="{Binding IsPage3Selected}"/> </StackPanel> ``` 其中,ContentTemplate使用了一个名为NavigationButtonTemplate的DataTemplate,它可以在Resources中定义,用于定义ToggleButton的显示内容。 3. 在Resources中定义NavigationButtonTemplate: ```xml <Window.Resources> <DataTemplate x:Key="NavigationButtonTemplate"> <StackPanel Orientation="Horizontal"> <Image Source="{Binding Icon}" Width="16" Height="16"/> <TextBlock Text="{Binding Text}" Margin="5,0,0,0"/> </StackPanel> </DataTemplate> </Window.Resources> ``` 其中,Image和TextBlock用于显示导航项的图标和文本,Icon和Text可以在ViewModel中绑定。 4. 在ViewModel中定义IsPage1Selected、IsPage2Selected、IsPage3Selected属性和NavigateToPage1Command、NavigateToPage2Command、NavigateToPage3Command命令,用于处理导航项的选择和导航操作。 这样,一个使用ToggleButton和StackPanel等控件结合DataTemplate实现自定义导航栏的例子就完成了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值