RadioButton-사용자 정의 드로어 블을 사용하는 방법?
RadioButton에서 다음을 사용할 수있는 것 같습니다.
android:button="@drawable/myCustomStateBackground"
하지만 드로어 블은 라디오 드로어 블이 일반적으로 이동하는 지점 만 차지합니다. 이상적으로는 전체 버튼 배경이 상태 저장되기를 원합니다. 따라서 눌렀을 때 전체 버튼이 눌린 상태에서 멈춘 것처럼 보이기를 원합니다. 이를 위해 다음과 같은 작업을 수행 할 수 있기를 바랐습니다.
android:button="null"
android:background="@drawable/myCustomStateBackground"
하지만 배경 드로어 블은 버튼 속성처럼 푸시 상태에 대해 알지 못합니다. 주위에 방법이 있습니까?
라디오 버튼에 사용자 정의 스타일을 지정하십시오.
<style name="MyRadioButtonStyle" parent="@android:style/Widget.CompoundButton.RadioButton">
<item name="android:button">@drawable/custom_btn_radio</item>
</style>
custom_btn_radio.xml
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_checked="true" android:state_window_focused="false"
android:drawable="@drawable/btn_radio_on" />
<item android:state_checked="false" android:state_window_focused="false"
android:drawable="@drawable/btn_radio_off" />
<item android:state_checked="true" android:state_pressed="true"
android:drawable="@drawable/btn_radio_on_pressed" />
<item android:state_checked="false" android:state_pressed="true"
android:drawable="@drawable/btn_radio_off_pressed" />
<item android:state_checked="true" android:state_focused="true"
android:drawable="@drawable/btn_radio_on_selected" />
<item android:state_checked="false" android:state_focused="true"
android:drawable="@drawable/btn_radio_off_selected" />
<item android:state_checked="false" android:drawable="@drawable/btn_radio_off" />
<item android:state_checked="true" android:drawable="@drawable/btn_radio_on" />
</selector>
드로어 블을 자신의 것으로 교체하십시오.
android:button="@null"
대신 설정해야합니다 "null"
.
당신은 너무 가까웠습니다!
여기에 전체 솔루션 :
<RadioGroup
android:id="@+id/radioGroup1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<RadioButton
android:id="@+id/radio0"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:button="@drawable/oragne_toggle_btn"
android:checked="true"
android:text="RadioButton" />
<RadioButton
android:id="@+id/radio1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:button="@drawable/oragne_toggle_btn"
android:layout_marginTop="20dp"
android:text="RadioButton" />
<RadioButton
android:id="@+id/radio2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:button="@drawable/oragne_toggle_btn"
android:layout_marginTop="20dp"
android:text="RadioButton" />
</RadioGroup>
선택기 XML
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@drawable/orange_btn_selected" android:state_checked="true"/>
<item android:drawable="@drawable/orange_btn_unselected" android:state_checked="false"/>
</selector>
if you want to change the only icon of radio button then you can only add android:button="@drawable/ic_launcher"
to your radio button and for making sensitive on click then you have to use the selector
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@drawable/image_what_you_want_on_select_state" android:state_checked="true"/>
<item android:drawable="@drawable/image_what_you_want_on_un_select_state" android:state_checked="false"/>
</selector>
and set to your radio android:background="@drawable/name_of_selector"
In programmatically, add the background image
minSdkVersion 16
RadioGroup rg = new RadioGroup(this);
RadioButton radioButton = new RadioButton(this);
radioButton.setBackground(R.drawable.account_background);
rg.addView(radioButton);
참고URL : https://stackoverflow.com/questions/12432553/radiobutton-how-to-use-a-custom-drawable
'Programing' 카테고리의 다른 글
전체 프로젝트 검색 및 바꾸기 (Netbeans) (0) | 2020.11.23 |
---|---|
출력을 bash 함수로 파이프 (0) | 2020.11.23 |
SQL Server에서 하위 쿼리를 사용하여 쿼리 업데이트 (0) | 2020.11.23 |
Xvfb 실패 시작 오류 (0) | 2020.11.23 |
Android 에스프레소에서 토스트 메시지 확인 (0) | 2020.11.23 |