Android Selektor & Textfarbe
-
10-07-2019 - |
Frage
Ich möchte eine einfache TextView
den Weg simple_list_item_1
verhalten in ein ListView
tut. Hier ist der 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" />
Alles funktioniert, außer für die Textfarbe, die (expectedly) nicht in fokussierten Zustand ändern. Wie kann ich es textAppearanceLargeInverse
machen ändern?
Lösung 2
Und Selektor ist die Antwort auch hier.
Suchen Sie nach bright_text_dark_focused.xml in den Quellen, zu einem Projekt unter res / Farbverzeichnis hinzufügen und dann aus dem Textview als
sieheandroid:textColor="@color/bright_text_dark_focused"
Andere Tipps
Ich habe durch mehrere Tests zu tun, bis man gearbeitet, so: res / Farbe / 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>
Hier ist meine Implementierung, die genau wie Punkt verhält sich in der Liste (zumindest auf 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 / Farbe / 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>
Um es auf Auswahl in einer Listenansicht funktioniert den folgenden Code verwenden:
<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>
Anscheinend ist der Schlüssel state_activated="true"
Zustand.
Hier ist das Beispiel des Wählers. Wenn Sie Eclipse verwenden, ist es nicht etwas vorschlagen, wenn Sie ctrl und Raum auf beide. / Sie es eingeben müssen
<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" />
Sie können als Referenz betrachten;
http://developer.android.com/guide/ Themen / resources / ziehbar-resource.html # StateList
Ich habe immer die obige Lösung ohne mehr danach zu suchen. ; -)
Doch heute bin ich auf etwas und dachte an sie zu teilen. :)
Mit dieser Funktion in der Tat von API 1 zur Verfügung und wird als genannt ColorStateList , wo wir eine Farbe verschiedene Zustände von Widgets liefern können (wie wir bereits wissen).
Es ist auch sehr gut dokumentiert, .
Wenn Textviews in Registerkarten dieser Selektor Definition für mich gearbeitet (versuchte Klaus Balduino die aber nicht) mit:
<?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>
Haben Sie setOnFocusChangeListener
versucht? Innerhalb des Handlers, können Sie den Text Aussehen verändern.
Zum Beispiel:
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();
}
}
});
Sie können dann anwenden, was Änderungen, die Sie wollen, wenn es fokussiert ist oder nicht. Sie können auch die ViewTreeObserver verwenden für globale Fokus Änderungen zu hören.
Zum Beispiel:
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
}
});
Ich hoffe, das hilft oder gibt Ihnen Ideen.
In res/color
Ort eine Datei "text_selector.xml":
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:color="@color/blue" android:state_focused="true" />
<item android:color="@color/blue" android:state_selected="true" />
<item android:color="@color/green" />
</selector>
Dann in TextView
verwendet es:
<TextView
android:id="@+id/value_1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Text"
android:textColor="@color/text_selector"
android:textSize="15sp"
/>
Und in Code Sie einen Klick-Listener müssen.
private var isPressed = false
private fun TextView.setListener() {
this.setOnClickListener { v ->
run {
if (isPressed) {
v.isSelected = false
v.clearFocus()
} else {
v.isSelected = true
v.requestFocus()
}
isPressed = !isPressed
}
}
}
override fun onResume() {
super.onResume()
textView.setListener()
}
override fun onPause() {
textView.setOnClickListener(null)
super.onPause()
}
Sorry, wenn es Fehler gibt, ich einen Code vor der Veröffentlichung geändert und nicht überprüfen.