我想要这种样子。他们看起来不像tabs
所以我相信他们是按钮。
我可以通过将选择器保留在drawable中来实现与toggle button
相似的类型。
<ToggleButton
android:id="@+id/toggleButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:background="@drawable/custom_selector"
android:textOn=" Button1 Button2"
android:textOff=" Button1 Button2" />
但是它们只有两个值,通过单击选中的选项卡,可以选择另一个选项,而不选择当前选项卡。但我想要像tab一样。有人可以帮我实现吗?提前谢谢。
答案 0 :(得分:14)
您必须为所有按钮创建选择器,并使用带有选择器背景和空按钮的RadioGroup
..
关注@Andru回答创建选择器..
以下是RadioGroup代码。
<RadioGroup
android:id="@+id/rdogrp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="8dp"
android:gravity="center"
android:orientation="horizontal" >
<RadioButton
android:id="@+id/btn1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="0dp"
android:background="@drawable/btn1Selector"
android:button="@null"
android:checked="true"
android:gravity="center" />
<RadioButton
android:id="@+id/btn2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="0dp"
android:background="@drawable/btn2Selector"
android:button="@null"
android:gravity="center" />
<RadioButton
android:id="@+id/btn3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="0dp"
android:background="@drawable/btn3Selector"
android:button="@null"
android:gravity="center" />
<RadioButton
android:id="@+id/btn4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="0dp"
android:background="@drawable/btn4Selector"
android:button="@null"
android:gravity="center" />
</RadioGroup>
这是btn1Selector.xml
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@drawable/btn1_selected" android:state_checked="true" />
<item android:drawable="@drawable/btn1_normal" android:state_checked="false"/>
</selector>
答案 1 :(得分:2)
你可以这样做,而不是切换按钮使用普通按钮。
如果单击“数据”按钮,则执行此操作
data(View v)
{
databtn.setBackgroundResource(R.drawable.image1);
w_chartbtn.setBackgroundResource(R.drawable.image2);
H_chartbtn.setBackgroundResource(R.drawable.image2);
}
如果点击“H图表”按钮
H_chart(View v)
{
databtn.setBackgroundResource(R.drawable.image2);
w_chartbtn.setBackgroundResource(R.drawable.image2);
H_chartbtn.setBackgroundResource(R.drawable.image1);
}
答案 2 :(得分:1)
使用简单按钮代替toogle按钮。并设置这样的背景:
我举1个按钮的例子:
android:background="@drawable/data_button_select_state"
在名为data_button_select_state的'drawable'文件夹中添加一个xml文件:
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >
<item android:drawable="@drawable/data_image_selected_state"
android:state_selected="true" />
<item android:drawable="@drawable/data_image_selected_state"
android:state_pressed="true" />
<item android:drawable="@drawable/data_image_without_selected" />
</selector>
现在在java文件中添加代码,如下所示:
点击数据按钮时:
data_button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
data_button.setActivated(true);
H_chart_button.setActivated(false);
w_chart_button.setActivated(false);
hc_chart_button.setActivated(false);
}
});
也可以更改其他按钮。这可能会对你有帮助......