Androidセレクターとテキストの色


184

単純なTextView方法simple_list_item_1で動作ListViewします。ここに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" />

フォーカスされた状態で(予想どおり)変化しないテキストの色を除いて、すべてが機能します。どうすれば変更できtextAppearanceLargeInverseますか?


場合には誰もがxmlファイルを探して、それはここにある:developer.android.com/resources/samples/Home/res/color/...
swinefeaster

回答:


404

1つが機能するまでいくつかのテストを行ったので、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>

8
android:
drawableがない

4
@neufuture:使用する必要がありますandroid:textColor="@color/button_dark_text"
Paul

3
色の状態のリストを記述した文書があります:developer.android.com/guide/topics/resources/...は
Rick77

好奇心として、それは、テキスト、ボタン、または任意のアイテムがアクティブになっている場合にも機能します(リストアイテムなど)。<item android:state_activated = "true" android:color = "@ android:color / white" />
ジアハオ

セレクターは本当にres/colorフォルダーの下に常駐する必要がありますか?
mr5

79

そして、セレクターもここでの答えです。

ソースでbright_text_dark_focused.xmlを検索し、res / colorディレクトリの下のプロジェクトに追加して、TextViewから次のように参照します

android:textColor="@color/bright_text_dark_focused"

5
これは「primary_text_dark_focused.xml」に変わったと思います。
greg7gkb 2010

11
これはちょうど私の心を吹き飛ばしました。これまでずっと、リスナーと一緒にテキストの色を変更するために物事を扱ってきました。床のあご。鮮やかさ!
Artem Russakovskii

セレクターがtextColorでも機能することは考えられませんでした。
Drejc

私が自分用に作成したビューのルートレイアウトでこれを試したところListFragment多くのエラーが発生しました。何が悪いのですか?
MowDownJoe 2013

@android:color / whiteは使用できません。Ctrl+スペースを押してもコンテンツアシスタンスを表示できない
LOG_TAG

31

これが私の実装です。リストの項目とまったく同じように動作します(少なくとも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>

これは私にとってはうまくいき、私の場合は私のTabHost実装の強調表示/非強調表示の色を調整するのに非常にうまくいきました
奇数メーター

27

リストビューでの選択で機能させるには、次のコードを使用します。

<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>

どうやらキーはstate_activated="true"状態です。


17
このファイルをres / colorフォルダーに配置することを忘れないでください
Nguyen Minh Binh

4

以下はセレクタの例です。eclipseを使用している場合、Ctrlキーとスペースの両方をクリックしても何も表示されません。入力する必要があります。

<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" />

参考までにご覧ください。

http://developer.android.com/guide/topics/resources/drawable-resource.html#StateList


2

私はいつもこれ以上検索せずに上記のソリューションを常に使用しました。;-)

しかし、今日私は何かに出会い、それを共有しようと考えました。:)

この機能は確かにAPI 1から利用可能で、ColorStateListと呼ばれ、ウィジェットのさまざまな状態に色を提供できます(すでに知っています)。

ここにも非常によく文書化されています。


2

res/color場所ファイル「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>

次にそれをTextView使用します:

<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"
    />

コードでは、クリックリスナーを設定する必要があります。

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()
}

エラーが発生した場合は申し訳ありませんが、公開前にコードを変更し、確認しませんでした。


1

タブでTextViewを使用する場合、このセレクター定義は私にとってはうまくいきました(Klaus Balduinoを試してみましたが、しませんでした):

<?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>

0

試しましたsetOnFocusChangeListenerか?ハンドラー内で、テキストの外観を変更できます。

例えば:

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();
        }
    }
});

次に、フォーカスされているかどうかに関係なく、必要な変更を適用できます。ViewTreeObserverを使用して、グローバルフォーカスの変更をリッスンすることもできます。

例えば:

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
    }
});

これがお役に立てば幸いです。


1
最初はこの方法で行きましたが、何らかの理由でテキストの色が変化しませんでした。
yanchenko 2009
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.