走马灯效果文字

走马灯效果的代码,对TextView进行一下重写即可:

public class AutoScrollTextView extends TextView {

public final static String TAG = AutoScrollTextView.class.getSimpleName();
private float mTxtLength = 0f;// 文本长度
private float step = 0f;// 文字的横坐标
private float y = 10f;// 文字的纵坐标
private float mInitX = 0.0f;// 初始文字坐标
private float mEndX = 0.0f;// 判断文字左面坐标.
private Paint paint = null;// 绘图样式
private String text = "";// 文本内容

public AutoScrollTextView(Context context) {
super(context);
}

public AutoScrollTextView(Context context, AttributeSet attrs) {
super(context, attrs);
}

public AutoScrollTextView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
}

public void init() {
paint = getPaint();
text = getText().toString();
mTxtLength = paint.measureText(text);
step = mTxtLength;
mInitX = getLeft() + getLayoutParams().width + mTxtLength;
mEndX = getLeft() + getLayoutParams().width + mTxtLength * 2;
y = getTextSize() + getPaddingTop();
invalidate();
}

@Override
public void onDraw(Canvas canvas) {
canvas.drawText(text, mInitX - step, y, paint);
step += 1;
if (step > mEndX) {
step = mTxtLength;
}
invalidate();
}

}


在Activity中调用一下init()方法即可.

布局文件还是贴一下吧:

<com.ex.AutoScrollTextView
android:id="@+id/TextViewNotice"
android:layout_width="100dp"
android:layout_height="30dp"
android:layout_marginLeft="100dp"
android:layout_marginTop="100dp"
android:background="#EEE"
android:paddingTop="5dp"
android:text="浮动的文字欢饮你......."
android:textColor="#000"
android:textSize="15sp" >
</com.ex.AutoScrollTextView>



今天补上一种系统自带的方法:

<TextView
android:id="@+id/mTxt"
android:layout_width="100dp"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:layout_marginTop="100dp"
android:ellipsize="marquee"
android:fadingEdge="none"
android:focusable="true"
android:focusableInTouchMode="true"
android:marqueeRepeatLimit="marquee_forever"
android:scrollHorizontally="true"
android:singleLine="true"
android:text="开放平台成网络淘金下一 ..."
android:textColor="@android:color/white"
android:textSize="18dip" />


直接设置对应TextView的文本内容即可.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值