第一种:
- Animation ani = new TranslateAnimation(310f, -400f, 0.0f, 0.0f);
- ani.setDuration(10000);
- ani.setRepeatCount(500);
- ani.setRepeatMode(1);
- TextView textView =(TextView) this.findViewById(R.id.text);
- textView .startAnimation(ani);
第二种:
我通过网上的一些例子自己在做了一些改动,就实现了现在不用获取焦点也能“跑”起来的效果。
首先,写一个类,让其继承自TextView:
- public class MarqueeText extends TextView {
- public MarqueeText(Context con) {
- super(con);
- }
- public MarqueeText(Context context, AttributeSet attrs) {
- super(context, attrs);
- }
- public MarqueeText(Context context, AttributeSet attrs, int defStyle) {
- super(context, attrs, defStyle);
- }
- @Override
- public boolean isFocused() {
- return true;
- }
- @Override
- protected void onFocusChanged(boolean focused, int direction,
- Rect previouslyFocusedRect) {
- }
- }
然后再将我们已经写好的这个控件(MarqueeText)放到布局文件中,例如main.xml:
<!-- 在布局文件中用自己写的控件只需要写类的全名就行,如下com.example这是包名,后面再跟类名就行了 -->
- <com.example.MarqueeText
- android:id="@+id/AMTV1"
- android:layout_width="400dip"
- android:layout_height="wrap_content"
- android:layout_marginLeft="80dip"
- android:textSize="25sp"
- android:textColor="@android:color/black"
- android:lines="1"
- android:focusable="true"
- android:focusableInTouchMode="true"
- android:scrollHorizontally="true"
- android:marqueeRepeatLimit="marquee_forever"
- android:ellipsize="marquee"
- android:background="#2FFFFFFF"
- android:text="这才是真正的文字跑马灯效果,文字移动速度,文字移动方向,文字移动的样式,动画等等……"
- />
关于MarqueeText类中为什么要复写onFocusChanged()方法,那是因为如果不写,在Textview 获得焦点后,再失去焦点时字就会停止“跑”了,所以如果想让它一直跑下去就复写onFocusChanged(),并且里面什么也不做(主要是不能调用父类的方法)。