android跑马灯源码,Android跑马灯的简单实现方式

本文介绍了两种在Android中实现跑马灯效果的方法。第一种利用`android:ellipsize`属性结合焦点获取实现,适用于文字从右至左滚动,要求字体长度大于控件长度。第二种方法通过定时器改变`TextView`的`padding`来达到滚动效果,可自由控制滚动方向,无特定长度要求。在使用第二种方法时,别忘了关闭定时器。

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

第一种:较简单,可是局限性强,貌似只能从右至左跑,且有一个要求:字体的长度需大于控件的长度,否则没有效果,重要的代码为深色部分,具体代码在文章最后。

e585e0395dfe94c4972f26c66f8eea27.png

重要代码的介绍

1. android:ellipsize=“marquee” 设置为跑马灯的显示方式

2. android:focusable=“true” 得到焦点

3. android:focusableInTouchMode=“true” 能够经过触动来获取焦点

4. android:marqueeRepeatLimit=“marquee_forever” 设置重复的次数

5. android:singleLine=“true” 单行显示android

第二种:利用定时器改变padding的值来起到跑马灯的效果,各个方向均可以,无第一种的要求,主要起到做用的为setPadding方法,在最后记得要关闭定时器!

1.布局文件

d425c580b5113050e4ecee4238e2b421.png

2.实现功能的代码

d93fa252e47a4fba893369985bf18dfb.png

再次强调记得关掉定时器!

具体代码以下:

第一种方法:web

android:text="班里发生什么了?不知道,先起哄再说。"

android:ellipsize="marquee"

android:focusable="true"

android:focusableInTouchMode="true"

android:marqueeRepeatLimit="marquee_forever"

android:singleLine="true"

android:layout_width="200dp"

android:layout_height="wrap_content" />

第二种方法:

布局文件:ide

android:id="@+id/mytext"

android:gravity="center_vertical"

android:text="班里发生什么了?不知道,先起哄再说。"

android:layout_width="match_parent"

android:layout_height="40dp" />

Java文件:svg

public class MainActivity extends Activity {

private TextView mytext;

private Handler handler;

private Runnable runnable;

private int theroll=0;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

initView();

marquee();//记得调用方法

}

private void initView() {

//实例化

mytext = (TextView) findViewById(R.id.mytext);

}

//滚动的具体代码

private void marquee(){

handler=new Handler();

runnable=new Runnable() {

@Override

public void run() {

if (theroll>80){

theroll=-80;

}

theroll=theroll+2;

//经过设置下面的四个参数能够起到控制滚动方向的做用

mytext.setPadding(theroll,0,0,0);

handler.postDelayed(this,100);//可调整速度

}

};

handler.postDelayed(runnable,0);

}

@Override

protected void onDestroy() {

super.onDestroy();

//在最后记得要关掉定时器

handler.removeCallbacks(runnable);

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值