android用TextView实现跑马灯效果

今天搞啦很久,其实很简单,就加几个属性就可以啦!

图如下 :






有的说要重写TextView方法,有的说要设置固定长度,但是我没重写也没有设置固定长度也弄出来啦!跑在2.3.3的手机上面。就是不知道其他地方能不能实现这种效果!


代码如下:(其他地方代码没什么关系)

  
    <TextView
		android:layout_width="fill_parent"
		android:layout_height="wrap_content"  
		android:id="@+id/notice"  
		android:background="@color/black20"   
		android:text="他们说这里是要放广告的,就是看看能不能动啊!长点...!!!!..."  
		android:ellipsize="marquee"  
		android:gravity="center"  
		android:textStyle="bold"  
		<span style="color:#ff0000;">android:focusable="true"  
		android:marqueeRepeatLimit="marquee_forever"  
		android:focusableInTouchMode="true"  
		android:scrollHorizontally="true"  
		android:singleLine="true"  </span>
		android:textSize="@dimen/activity_Textsize15_4.0"  
		/>  
   

注意的就是内容一点要够长才会滚动,不然就不会滚动。 红色标记的代码是关键代码。


但是这样子有一个缺点,就是这种状态的跑马灯只能在TextView处于焦点状态的时候,它才会滚动,对于实际的开发应用中很不实用,

为了是跑马灯无论在什么情况下都能跑起来,这里需要自定义一个TextView,它继承TextView,并且重写isFocuse()方法,让它永远返回true,

这样跑马灯效果就能一直的跑起来了。

[java]  view plain copy
  1. public class MarqueeTextView extends TextView {  
  2.   
  3.     public MarqueeTextView(Context context) {  
  4.         super(context);  
  5.     }  
  6.       
  7.     public MarqueeTextView(Context context, AttributeSet attrs) {  
  8.         super(context, attrs);  
  9.     }  
  10.   
  11.     public MarqueeTextView(Context context, AttributeSet attrs,  
  12.             int defStyle) {  
  13.         super(context, attrs, defStyle);  
  14.     }  
  15.       
  16.     @Override  
  17.     public boolean isFocused() {  
  18.         return true;  
  19.     }  
  20.   
  21. }  


在xml中引用

[html]  view plain copy
  1. <com.heynine.widget.view.MarqueeTextView  
  2.         android:layout_width="fill_parent"  
  3.         android:layout_height="wrap_content"  
  4.         android:ellipsize="marquee"  
  5.         android:marqueeRepeatLimit="marquee_forever"  
  6.         android:singleLine="true"  
  7.         android:text="@string/marquee_text1" />  
  8.   
  9.     <com.heynine.widget.view.MarqueeTextView  
  10.         android:layout_width="fill_parent"  
  11.         android:layout_height="wrap_content"  
  12.         android:ellipsize="marquee"  
  13.         android:marqueeRepeatLimit="marquee_forever"  
  14.         android:singleLine="true"  
  15.         android:text="@string/marquee_text2" />  

这样就可以显示了
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值