【问题标题】:set state to buttons by default默认情况下将状态设置为按钮
【发布时间】:2017-09-07 10:44:31
【问题描述】:

我有两个文本视图,我想更改它们的背景图像。

<TextView
            android:layout_width="@dimen/margin_0dp"
            android:layout_height="wrap_content"
            android:layout_weight="0.5"
            android:layout_margin="@dimen/margin_padding_2dp"
            android:padding="@dimen/margin_padding_5dp"
            android:text="Trainings"
            android:gravity="center"
            android:textSize="17sp"
            android:background="@drawable/background_selector"
            android:clickable="true"
            />
        <TextView
            android:id="@+id/learning_programs"
            android:layout_width="@dimen/margin_0dp"
            android:layout_height="wrap_content"
            android:layout_weight="0.5"
            android:text="Learning Programs"
            android:padding="@dimen/margin_padding_5dp"
            android:textSize="@dimen/text_size_seventeen"
            android:background="@drawable/background_selector"
            android:gravity="center"
            android:clickable="true"
            />

所以,我想要的是,当我单击 TextView 时,背景图像应该会发生变化。为此,我在 drawable 中有一个选择器

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:drawable="@drawable/rounded_corner" android:state_pressed="true"/>
    <item android:drawable="@drawable/rounded_corner" android:state_focused="true"/>

    <item android:drawable="@drawable/rounded_corner_grey"/>
</selector>

但是上面代码的问题是只有当用户点击 TextView 时它才会保留白色。一旦用户的手指移动,颜色就会变为灰色。

我想要的是在用户单击 TextView 一次后颜色应该变为白色。

state_selected:true 两个 TextView 都变成白色且不可点击。

【问题讨论】:

    标签: android xml android-layout


    【解决方案1】:

    将这行代码添加到两个文本视图中。

    android:focusableInTouchMode="true"

    这意味着当手机处于触摸模式时,视图可以获得焦点。

    编辑: 试试这个 xml 并检查它是否有效。

    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    
    <TextView
        android:layout_width="@dimen/margin_0dp"
        android:layout_height="wrap_content"
        android:layout_margin="@dimen/margin_padding_2dp"
        android:layout_weight="0.5"
        android:background="@drawable/background_selector"
        android:clickable="true"
        android:focusable="true"
        android:focusableInTouchMode="true"
        android:gravity="center"
        android:padding="@dimen/margin_padding_5dp"
        android:text="Trainings"
        android:textSize="17sp" />
    
    <TextView
        android:id="@+id/learning_programs"
        android:layout_width="@dimen/margin_0dp"
        android:layout_height="wrap_content"
        android:layout_weight="0.5"
        android:background="@drawable/background_selector"
        android:clickable="true"
        android:focusable="true"
        android:focusableInTouchMode="true"
        android:gravity="center"
        android:padding="@dimen/margin_padding_5dp"
        android:text="Learning Programs"
        android:textSize="@dimen/text_size_seventeen" />
    

    【讨论】:

    • 它应该可以工作。我已将您的代码复制到我的工作室并检查了伙计。
    • 不,不是。我也在尝试同样的事情。
    • 尝试添加 android:focusable="true" 并告诉我,无论如何对我来说它的工作..in emulator 8.0
    • 您正在使用上面提供的xml和选择器吗?不要对其进行任何更改。它很完美。当您单击文本视图时会发生什么?
    • 它变成白色,当我取消点击它时,它又变成灰色。我想要的是白色应该在点击一次后保留
    【解决方案2】:

    当您的手指从视图中松开时,您的视图不处于selectedpressed 状态。点击事件后需要手动设置pressedselected状态。

     <TextView
        android:id="@+id/sample_text"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:clickable="true"
        android:background="@drawable/background_selector"
        android:text="Hello World!" />
    

    然后在你的代码中

    TextView tv = (TextView) findViewById(R.id.sample_text);
    tv.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            v.setSelected(!v.isSelected());
        }
    });
    

    您可以将一个OnClickListener 用于两个TextView

    private View.OnClickListener toggleSelectedStateOnClickListener = new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            v.setSelected(!v.isSelected());
        }
    };
    
    TextView tv = (TextView) findViewById(R.id.sample_text);
    tv.setOnClickListener(toggleSelectedStateOnClickListener);
    
    TextView tv1 = new TextView(this);
    tv1.setOnClickListener(toggleSelectedStateOnClickListener);
    

    【讨论】:

    • 我有两个 TextViews,我该如何概括?
    • 通过这段代码,我可以同时选择两个文本视图。有没有办法一次选择一个,如果我选择另一种方式,第一个会自动取消选择?
    【解决方案3】:

    就我而言,我使用这个:

     <?xml version="1.0" encoding="utf-8"?>
    <selector xmlns:android="http://schemas.android.com/apk/res/android">
            <item android:color="@color/bottom_nav_normal" android:state_enabled="true"/>
            <item android:color="@color/bottom_nav_checked" android:state_enabled="false"/>
            <item android:color="@color/bottom_nav_checked" android:state_pressed="true"/>
        </selector>
    

    那么,在代码中:

    TextView tv = (TextView)findViewById(R.id.tv);
    tv.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                //TODO
                tv.setEnable(false);
            }
        }
    

    【讨论】:

    • 我认为你应该编写一个自定义视图更有效
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-09-25
    • 1970-01-01
    • 1970-01-01
    • 2012-08-09
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多