Jego całkiem proste :) Najpierw trzeba utworzyć klasę, która CustomCheckBox rozszerzy CheckBox i zastąpi metodę onDraw(Canvas canvas)
:
public class CustomCheckBox extends CheckBox {
private final Drawable buttonDrawable;
public CustomCheckBox(Context context, AttributeSet set) {
super(context, set);
buttonDrawable = getResources().getDrawable(R.drawable.custom_check_box);
try {
setButtonDrawable(android.R.color.transparent);
} catch (Exception e) {
// DO NOTHING
}
setPadding(10, 5, 50, 5);
}
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
buttonDrawable.setState(getDrawableState());
final int verticalGravity = getGravity() & Gravity.VERTICAL_GRAVITY_MASK;
final int height = buttonDrawable.getIntrinsicHeight();
if (buttonDrawable != null) {
int y = 0;
switch (verticalGravity) {
case Gravity.BOTTOM:
y = getHeight() - height;
break;
case Gravity.CENTER_VERTICAL:
y = (getHeight() - height)/2;
break;
}
int buttonWidth = buttonDrawable.getIntrinsicWidth();
int buttonLeft = getWidth() - buttonWidth - 5;
buttonDrawable.setBounds(buttonLeft, y, buttonLeft + buttonWidth, y + height);
buttonDrawable.draw(canvas);
}
}
}
stworzyć także swój przełącznik nazwany custom_check_box
w swojej rozciągliwej folderu:
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_checked="true" android:state_window_focused="false"
android:drawable="@drawable/btn_check_on" />
<item android:state_checked="false" android:state_window_focused="false"
android:drawable="@drawable/btn_check_off" />
<item android:state_checked="true" android:state_pressed="true"
android:drawable="@drawable/btn_check_on" />
<item android:state_checked="false" android:state_focused="true"
android:drawable="@drawable/btn_check_off" />
<item android:state_checked="false" android:drawable="@drawable/btn_check_off" />
<item android:state_checked="true" android:drawable="@drawable/btn_check_on" />
</selector>
i używać niestandardowych ikon/IMG w XML powyżej dla wszystkich trzech stanach (focused/prasowanego/default)
używać składnika niestandardowego w XML tak:
<*package + class path*.CustomCheckBox // example com.mypackage.ui.CustomCheckBox if your project is named "mypackage" and the class is in the "ui" folder
android:text="@string/text"
android:checked="false" android:layout_width="fill_parent"
android:id="@+id/myCheckbox" android:layout_height="wrap_content"/>
i Java:
private CustomCheckBox mCheckbox;
mCheckbox = (CustomCheckBox) findviewbyid(R.id.myCheckbox);
Działa, ponieważ użyłem go w obie strony :) A z kilkoma poprawkami działa również dla RadioButtons w ten sam sposób. Szczęśliwe kodowanie!
Dzięki! Działa doskonale dla mnie ... –
jeśli chcę odznaczyć sprawdzony element, która właściwość selektora może być używana .. –
Muszę programowo checkbox gen jak używać niestandardowego checkBox ktoś ma pomysł? – UmAnusorn