versiones pie oreo developer descargar android

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"