Android自定義跑馬燈文字效果
更新時間:2020年03月11日 10:27:12 作者:廣靚
這篇文章主要為大家詳細介紹了Android自定義跑馬燈文字效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了Android自定義跑馬燈文字的具體代碼,供大家參考,具體內(nèi)容如下
Android 跑馬燈效果文字:
效果圖(真實動畫很流暢,這個轉(zhuǎn)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; //判斷是否滾動結(jié)束 if (drawTextX > textLength) { drawTextX = -canvas.getWidth(); } invalidate(); } }
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- Android 中TextView中跑馬燈效果的實現(xiàn)方法
- Android TextView實現(xiàn)跑馬燈效果的方法
- Android實現(xiàn)跑馬燈效果的方法
- Android自定義View實現(xiàn)豎直跑馬燈效果案例解析
- Android實現(xiàn)圖文垂直跑馬燈效果
- Android中使用TextView實現(xiàn)文字跑馬燈效果
- Android自定義textview實現(xiàn)豎直滾動跑馬燈效果
- Android基于TextView不獲取焦點實現(xiàn)跑馬燈效果
- Android跑馬燈MarqueeView源碼解析
- android自定義View實現(xiàn)跑馬燈效果
相關文章
Android 使用Picasso加載網(wǎng)絡圖片等比例縮放的實現(xiàn)方法
在做android圖片加載的時候,由于手機屏幕受限,很多大圖加載過來的時候,我們要求等比例縮放,接下來小編給大家?guī)砹薃ndroid 使用Picasso加載網(wǎng)絡圖片等比例縮放的實現(xiàn)方法,感興趣的朋友一起看看吧2018-08-08Android實現(xiàn)Unity3D下RTMP推送的示例
像Unity3D下的RTMP或RTSP播放器一樣,好多開發(fā)者苦于在Unity環(huán)境下,如何高效率低延遲的把數(shù)據(jù)采集并編碼實時推送到流媒體服務器,實現(xiàn)Unity場景下的低延遲推拉流方案。本文介紹幾種RTMP推送的方案2021-06-06Android開發(fā)實現(xiàn)文件關聯(lián)方法介紹
這篇文章主要介紹了Android開發(fā)實現(xiàn)文件關聯(lián)方法介紹,具有一定參考價值,需要的朋友樂意了解下。2017-10-10百度地圖實現(xiàn)小車規(guī)劃路線后平滑移動功能
這篇文章主要介紹了百度地圖實現(xiàn)小車規(guī)劃路線后平滑移動功能,本文是小編寫的一個demo,通過效果圖展示的非常直白,需要的朋友可以參考下2020-01-01Android列表組件ListView使用詳解之動態(tài)加載或修改列表數(shù)據(jù)
今天小編就為大家分享一篇關于Android列表組件ListView使用詳解之動態(tài)加載或修改列表數(shù)據(jù),小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-03-03android studio安裝時 AVD出現(xiàn)問題如何快速解決
這篇文章主要介紹了安裝android studio時 AVD出現(xiàn)問題如何快速處理,其實解決方法也很簡單,文中通過截圖的形式給大家及時的非常詳細,對大家的工作或?qū)W習具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03