문제

나는 간단한 것을 원한다 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?

도움이 되었습니까?

해결책 2

그리고 선택기도 여기서 답입니다.

Bright_Text_dark_focused.xml을 검색 소스에서 Res/Color Directory에서 프로젝트에 추가 한 다음 TextView에서 다음과 같이 참조하십시오.

android:textColor="@color/bright_text_dark_focused"

다른 팁

일이 일할 때까지 여러 테스트를 수행하여 : RES/COLOR/BUCTLE_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>

내 구현은 다음과 같습니다.이 구현은 목록의 항목으로 정확히 작동합니다 (최소 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>

목록보기에서 선택에서 작동하도록하려면 다음 코드를 사용하십시오.

<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" 상태.

다음은 선택기의 예입니다. 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

나는이 후에 더 많은 것을 검색하지 않고 항상 위의 솔루션을 사용했습니다. ;-)

그러나 오늘 나는 무언가를 발견하고 그것을 공유 할 생각을했습니다. :)

이 기능은 실제로 API 1에서 사용할 수 있으며 ColorStatelist, 우리는 이미 알고 있듯이 다양한 위젯 상태에 색상을 공급할 수 있습니다.

또한 매우 잘 문서화되어 있습니다. 여기.

탭에서 TextViews를 사용하는 경우이 선택기 정의는 저에게 효과적이었습니다 (Klaus Balduino 's를 시도했지만 그렇지 않았습니다).

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

당신은 시도 했습니까? 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
    }
});

이것이 도움이되거나 아이디어를 제공하기를 바랍니다.

~ 안에 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()
}

오류가 있으면 죄송합니다. 게시하기 전에 코드를 변경했지만 확인하지 않았습니다.

라이센스 : CC-BY-SA ~와 함께 속성
제휴하지 않습니다 StackOverflow
scroll top