Android自定义跑马灯文字效果
更新时间:2020年03月11日 10:27:12 作者:广靓
这篇文章主要为大家详细介绍了Android自定义跑马灯文字效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了Android自定义跑马灯文字的具体代码,供大家参考,具体内容如下
Android 跑马灯效果文字:
效果图(真实动画很流畅,这个转gif有问题,感觉有点卡):

代码:
/**
* Created by wuguangliang on 2018/12/21
*
* 跑马灯效果文字
*/
public class MarqueeHorizontalTextView extends AppCompatTextView {
private float textLength = 0f;
private float drawTextX = 0f;// 文本的横坐标
public boolean isStarting = false;// 是否开始滚动
private Paint paint = null;
private String text = "";
private long waitTime = 1000; //开始时等待的时间
private int scrollTile = 2; //文字的滚动速度
private int baseline;
public MarqueeHorizontalTextView(Context context) {
super(context);
initView(context);
}
public MarqueeHorizontalTextView(Context context, AttributeSet attrs) {
super(context, attrs);
initView(context);
}
public MarqueeHorizontalTextView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
initView(context);
}
private void initView(Context context) {
setMaxWidth(context.getResources().getDisplayMetrics().widthPixels / 2); //因为需求需要所以设置了最大宽度,如果不需要此功能可以删除掉
paint = getPaint();
paint.setColor(getTextColors().getColorForState(getDrawableState(), 0));
text = getText().toString();
if (TextUtils.isEmpty(text)) {
return;
}
textLength = paint.measureText(text);
isStarting = true;
}
@Override
public void setTextColor(int color) {
super.setTextColor(color);
paint.setColor(color);
start();
}
@Override
public void setText(CharSequence text, BufferType type) {
super.setText(text, type);
this.text = text.toString();
this.textLength = getPaint().measureText(text.toString());
drawTextX = 0;
start();
}
public void start() {
isStarting = true;
invalidate();
}
public void stop() {
isStarting = false;
invalidate();
}
@Override
public void onDraw(Canvas canvas) {
final Paint.FontMetricsInt fontMetrics = paint.getFontMetricsInt();
baseline = (canvas.getHeight() - fontMetrics.bottom - fontMetrics.top) / 2;
if (textLength <= canvas.getWidth()) {
canvas.drawText(text, 0, baseline, paint);
return;
}
canvas.drawText(text, -drawTextX, baseline, paint);
if (!isStarting) {
return;
}
if (drawTextX == 0) {
postDelayed(() -> {
drawTextX = 1;
isStarting = true;
invalidate();
}, waitTime);
isStarting = false;
return;
}
drawTextX += scrollTile;
//判断是否滚动结束
if (drawTextX > textLength) {
drawTextX = -canvas.getWidth();
}
invalidate();
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
Android ContentObserver 监听短信思路详解
ContentObserver允许在Android中监控特定数据的变化,可用于短信等应用的数据监听,开发者可通过继承ContentObserver并实现onChange方法来定义当目标内容变化时的响应行为,感兴趣的朋友一起看看吧2024-09-09
Android编程中PopupWindow的用法分析【位置、动画、焦点】
这篇文章主要介绍了Android编程中PopupWindow的用法,结合实例形式分析了PopupWindow控件位置、动画、焦点等操作相关技巧,需要的朋友可以参考下2017-02-02
Android学习笔记(一)环境安装及第一个hello world
最近在学习安卓开发,记录下环境安装和第一个hello world的诞生过程,希望对大家有所帮助2014-07-07


最新评论