Textview自定义跑马灯效果 不受其他焦点影响

本文详细介绍了如何在Android中实现TextView的跑马灯效果,包括XML配置和代码实现,并提供了一个自定义的MarqueeScrollTextView类,展示了如何在Adapter中使用此组件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

布局文件:

     <com.baofeng.tv.local.widget.MarqueeScrollTextView
                android:id="@+id/tv_menu_conten"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_centerHorizontal="true"
                android:layout_marginLeft="@dimen/dp_14"
                android:layout_marginRight="@dimen/dp_15"
                android:marqueeRepeatLimit="marquee_forever"
                android:maxLines="1"
                android:singleLine="true"
                android:textColor="#FFFFFF"
                android:textSize="@dimen/sp_22" />

以下是代码设置这个Textview的属性 必须要有焦点和跑马灯横向滑动的属性 已可以选择在XMl文件里面配置根据个人所需        我这个是在adapter使用控制   

               holde.tvMenuConten.setFocusable(true);
                holde.tvMenuConten.setEllipsize(TruncateAt.MARQUEE);
                holde.tvMenuConten.setHorizontallyScrolling(true);

下面就来重写Textview吧 实现跑马灯

/**重写Textview 实现跑马灯
 * @author jiangbing
 * @time 2015-5-15 上午11:44:02
 */
public class MarqueeScrollTextView extends TextView {

    private static final String TAG = "MarqueeScrollTextView";

    public MarqueeScrollTextView(Context context) {

        super(context);

        // TODO Auto-generated constructor stub
    }

    public MarqueeScrollTextView(Context context, AttributeSet attrs) {

        super(context, attrs);

        // TODO Auto-generated constructor stub
    }

    public MarqueeScrollTextView(Context context, AttributeSet attrs, int defStyle) {

        super(context, attrs, defStyle);

        // TODO Auto-generated constructor stub
    }

    @Override
    public boolean isFocused() {

        return true;

    }

    @Override
    protected void onFocusChanged(boolean focused, int direction, Rect previouslyFocusedRect) {

        // TODO Auto-generated method stub
        // fobid call parent constructor
        // super.onFocusChanged(focused, direction, previouslyFocusedRect);
    }
}


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值