android+自定义跑马灯,android自定义TextView跑马灯

这篇博客介绍了如何自定义MScollingTextView类,它扩展了TextView并实现焦点管理和选中状态。方法包括获取和设置焦点、选中状态,以及调整文本大小和布局。核心内容涉及文本视图的个性化控制和性能优化。
摘要由CSDN通过智能技术生成

public class MScollingTextView extends TextView implements IView {

private boolean mHasMFocus

= false;

private boolean mIsMSelected

= false;

public

MScollingTextView(Context context) {

super(context);

init();

}

public

MScollingTextView(Context context, AttributeSet attrs) {

super(context, attrs);

init();

}

public

MScollingTextView(Context context, AttributeSet attrs, int defStyleAttr) {

super(context, attrs,

defStyleAttr);

init();

}

// layout params

@Override

public ViewGroup.LayoutParams

getMLayoutParams() {

return getLayoutParams();

}

@Override

public int getMHeight() {

return getHeight();

}

@Override

public int getMWidth() {

return getWidth();

}

@Override

public void

setMLayoutParams(ViewGroup.LayoutParams params) {

setLayoutParams(params);

}

// padding

@Override

public int getMPaddingBottom() {

return getPaddingBottom();

}

@Override

public int getMPaddingLeft() {

return getPaddingLeft();

}

@Override

public int getMPaddingRight() {

return getPaddingRight();

}

@Override

public int getMPaddingTop() {

return getPaddingTop();

}

@Override

public void setMPadding(int left, int top, int right, int bottom) {

setPadding((left),

(top),(right),

(bottom));

}

// focus

@Override

public

boolean hasMFocus() {

return

mHasMFocus;

}

@Override

public

void setMFocus(boolean focused) {

mHasMFocus = focused;

OnFocusChangeListener l =

getOnFocusChangeListener();

if

(null != l) {

l.onFocusChange(this, mHasMFocus);

}

}

// selected

@Override

public boolean isMSelected() {

return

mIsMSelected;

}

@Override

public void setMSelected(boolean selected) {

mIsMSelected = selected;

}

// text size

public float getMTextSize() {

return

Util.convertOut(getTextSize());

}

public void setMTextSize(float size) {

setTextSize(TypedValue.COMPLEX_UNIT_PX, Util.convertIn(size));

}

public void setMTextSize(int unit, float size) {

setTextSize(TypedValue.COMPLEX_UNIT_PX, Util.convertIn(size));

}

// init

private void init() {

setMTextSize(TypedValue.COMPLEX_UNIT_PX, getTextSize());

setMPadding(

getPaddingLeft(),

getPaddingTop(),

getPaddingRight(), getPaddingBottom());

setSingleLine(true);

setFocus(false);

mReseted = true;

mMeasureSpec =

MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED);

}

@Override

public void setFlash(Flash flash) {

// TODO Auto-generated method

stub

}

@SuppressLint("Override") @Override

public float getCameraDistance() {

// TODO Auto-generated method

stub

return 0;

}

public void setFocus(boolean focused) {

mHasFocus = focused;

mReseted = true;

if (mHasFocus)

{

setEllipsize(TruncateAt.MARQUEE);

setMarqueeRepeatLimit(-1);

} else {

setEllipsize(TruncateAt.END);

}

invalidate();

}

// ---------------- override ----------------

@Override

public boolean requestFocus(int direction, Rect previouslyFocusedRect)

{

return false;

}

@Override

protected void onDraw(Canvas canvas) {

if

(mHasFocus) {

if

(mReseted) {

mStart

= System.currentTimeMillis();

mReseted = false;

}

scroll(canvas);

} else

{

super.onDraw(canvas);

}

}

@SuppressLint("WrongCall")

private void scroll(Canvas canvas) {

long current =

System.currentTimeMillis();

long delta;

delta = current - mStart;

measure(mMeasureSpec,

mMeasureSpec);

int measureWidth =

getMeasuredWidth();

if (delta>mScrollWait &&

measureWidth>getWidth()) {

int firstOffset = (int) ((delta-mScrollWait)

* mScrollRatio);

int threshold = measureWidth +

mTextGap;

if (firstOffset > threshold) {

firstOffset %= threshold;

mStart = current;

}

firstOffset = -firstOffset;

int secondOffsset = firstOffset +

measureWidth + mTextGap;

// first

setPadding(firstOffset, 0, 0, 0);

super.onDraw(canvas);

// second

setPadding(secondOffsset, 0, 0,

0);

super.onDraw(canvas);

} else {

super.onDraw(canvas);

}

setPadding(0, 0, 0, 0);

invalidate();

}

// ---------------- property ----------------

private boolean mHasFocus;

private boolean mReseted;

private long mStart;

private int mMeasureSpec;

private double mScrollRatio

= 0.04;

private int mTextGap

= 50;

private long mScrollWait = 1000;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值