Android跑马灯的简单实现方式

第一种:较简单,但是局限性强,貌似只能从右至左跑,且有一个要求:字体的长度需大于控件的长度,不然没有效果,重要的代码为深色部分,具体代码在文章最后。
在这里插入图片描述
重要代码的介绍
1. android:ellipsize=“marquee” 设置为跑马灯的显示方式
2. android:focusable=“true” 获得焦点
3. android:focusableInTouchMode=“true” 可以通过触动来获取焦点
4. android:marqueeRepeatLimit=“marquee_forever” 设置重复的次数
5. android:singleLine=“true” 单行显示

第二种:利用定时器改变padding的值来起到跑马灯的效果,各个方向都可以,无第一种的要求,主要起到作用的为setPadding方法,在最后记得要关闭定时器!
1.布局文件
在这里插入图片描述
2.实现功能的代码
在这里插入图片描述
再次强调记得关掉定时器!
具体代码如下:
第一种方法:

<TextView
    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" />

第二种方法:
布局文件:

<TextView
        android:id="@+id/mytext"
        android:gravity="center_vertical"
        android:text="班里发生什么了?不知道,先起哄再说。"
        android:layout_width="match_parent"
        android:layout_height="40dp" />

Java文件:

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);
    }
}
  • 25
    点赞
  • 39
    收藏
    觉得还不错? 一键收藏
  • 14
    评论
评论 14
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值