oreo - android pie
Selector de Android y color del texto (8)
Quiero que un simple TextView
comporte como lo hace simple_list_item_1
en un ListView
. Aquí está el XML:
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_height="wrap_content" android:layout_width="fill_parent"
android:gravity="center" android:focusable="true"
android:minHeight="?android:attr/listPreferredItemHeight"
android:textAppearance="?android:attr/textAppearanceLarge"
android:background="@android:drawable/list_selector_background" />
Todo funciona, excepto el color del texto que (esperablemente) no cambia en el estado enfocado. ¿Cómo puedo hacer que cambie a textAppearanceLargeInverse
?
¿Has probado setOnFocusChangeListener
? Dentro del controlador, puede cambiar la apariencia del texto.
Por ejemplo:
TextView text = (TextView)findViewById(R.id.text);
text.setOnFocusChangeListener(new View.OnFocusChangeListener() {
public void onFocusChange(View v, boolean hasFocus) {
if (hasFocus) {
((TextView)v).setXXXX();
} else {
((TextView)v).setXXXX();
}
}
});
A continuación, puede aplicar los cambios que desee cuando esté enfocado o no. También puede usar ViewTreeObserver para escuchar los cambios de enfoque globales.
Por ejemplo:
View all = findViewById(R.id.id_of_top_level_view_on_layout);
ViewTreeObserver vto = all.getViewTreeObserver();
vto.addOnGlobalFocusChangeListener(new ViewTreeObserver.OnGlobalFocusChangeListener() {
public void onGlobalFocusChanged(
View oldFocus, View newFocus) {
// xxxx
}
});
Espero que esto te ayude o te dé ideas.
Aquí está el ejemplo de selector. Si usa eclipse, no sugiere algo cuando hace clic en ctrl y espacio en ambos: / debe escribirlo.
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@drawable/btn_default_pressed" android:state_pressed="true" />
<item android:drawable="@drawable/btn_default_selected"
android:state_focused="true"
android:state_enabled="true"
android:state_window_focused="true" />
<item android:drawable="@drawable/btn_default_normal" />
Puedes mirar para referencia;
http://developer.android.com/guide/topics/resources/drawable-resource.html#StateList
Aquí está mi implementación, que se comporta exactamente como elemento en la lista (al menos en 2.3)
res / layout / list_video_footer.xml
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<TextView
android:id="@+id/list_video_footer"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="@android:drawable/list_selector_background"
android:clickable="true"
android:gravity="center"
android:minHeight="98px"
android:text="@string/more"
android:textColor="@color/bright_text_dark_focused"
android:textSize="18dp"
android:textStyle="bold" />
</FrameLayout>
res / color / bright_text_dark_focused.xml
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_selected="true" android:color="#444"/>
<item android:state_focused="true" android:color="#444"/>
<item android:state_pressed="true" android:color="#444"/>
<item android:color="#ccc"/>
</selector>
Obtuve varias pruebas hasta que funcionó, así que: res / color / button_dark_text.xml
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="true"
android:color="#000000" /> <!-- pressed -->
<item android:state_focused="true"
android:color="#000000" /> <!-- focused -->
<item android:color="#FFFFFF" /> <!-- default -->
</selector>
res / layout / view.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
>
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="EXIT"
android:textColor="@color/button_dark_text" />
</LinearLayout>
Para hacer que funcione en la selección en una vista de lista, use el siguiente código:
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="true" android:color="#fff"/>
<item android:state_activated="true" android:color="#fff"/>
<item android:color="#000" />
</selector>
Aparentemente la clave es state_activated="true"
.
Si utilizo TextViews en pestañas, esta definición de selector funcionó para mí (probé la de Klaus Balduino pero no fue así):
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<!-- Active tab -->
<item
android:state_selected="true"
android:state_focused="false"
android:state_pressed="false"
android:color="#000000" />
<!-- Inactive tab -->
<item
android:state_selected="false"
android:state_focused="false"
android:state_pressed="false"
android:color="#FFFFFF" />
</selector>
Siempre utilicé la solución anterior sin buscar más después de esto. ;-)
Sin embargo, hoy me encontré con algo y pensé en compartirlo. :)
Esta característica, de hecho, está disponible desde API 1 y se llama ColorStateList , donde podemos suministrar un color a varios estados de Widgets (como ya sabemos).
También está muy bien documentado, here.
Y selector es la respuesta aquí también.
Busque bright_text_dark_focused.xml en las fuentes, agréguelo a su proyecto en el directorio res / color y luego refiérase desde TextView como
android:textColor="@color/bright_text_dark_focused"