Android view特效,Android 特效View第三弹之闪烁View

package com.example.empty;

import java.util.Timer;

import java.util.TimerTask;

import android.annotation.SuppressLint;

import android.content.Context;

import android.graphics.Color;

import android.os.Handler;

import android.os.Message;

import android.util.AttributeSet;

import android.widget.TextView;

public class FlickerTextView extends TextView{

boolean change = false;

private Handler handler = null;

public FlickerTextView(Context context, AttributeSet attrs) {

super(context, attrs);

// TODO Auto-generated constructor stub

startFlicker();

}

@SuppressLint("HandlerLeak")

public void startFlicker(){

handler = new Handler(){

@Override

public void dispatchMessage(Message msg) {

if(change){

change = false;

setTextColor(Color.TRANSPARENT); //这个是透明,=看不到文字

}else{

change = true;

setTextColor(Color.RED);

}

}

};

Timer timer = new Timer();

TimerTask task = new TimerTask() {

@Override

public void run() {

Message msg = new Message();

handler.sendMessage(msg);

}

};

timer.schedule(task,1,300); //参数分别是delay(多长时间后执行),duration(执行间隔)

}

}

package com.example.empty;

import android.content.Context;

import android.graphics.Canvas;

import android.util.AttributeSet;

import android.widget.TextView;

public class FlickerText extends TextView{

public FlickerText(Context context, AttributeSet attrs) {

super(context, attrs);

// TODO Auto-generated constructor stub

}

interface STATE{

static final int VISIBLE = 1;

static final int INVISIBLE = 0;

}

@Override

protected void onDraw(Canvas canvas) {

super.onDraw(canvas);

switch(getAlphastate()){

case STATE.VISIBLE:{

setAlpha(STATE.INVISIBLE);

break;

}

case STATE.INVISIBLE:{

setAlpha(STATE.VISIBLE);

break;

}

}

postInvalidateDelayed(300);

}

public int getAlphastate(){

return (int)getAlpha()== STATE.INVISIBLE ? STATE.INVISIBLE:STATE.VISIBLE;

}

}

package com.example.empty;

import java.util.Timer;

import java.util.TimerTask;

import android.content.Context;

import android.os.Handler;

import android.os.Message;

import android.util.AttributeSet;

import android.widget.ImageView;

public class FlikerImageView extends ImageView {

boolean change = false;

public FlikerImageView(Context context, AttributeSet attrs) {

super(context, attrs);

// TODO Auto-generated constructor stub

startFlicker();

}

interface STATE {

static final int VISIBLE = 255;

static final int INVISIBLE = 0;

}

private Handler handler = new Handler() {

@Override

public void dispatchMessage(Message msg) {

if (change) {

change = false;

setImageAlpha(STATE.INVISIBLE);

} else {

change = true;

setImageAlpha(STATE.VISIBLE);

}

}

};

public void startFlicker() {

Timer timer = new Timer();

TimerTask task = new TimerTask() {

@Override

public void run() {

Message msg = new Message();

handler.sendMessage(msg);

}

};

timer.schedule(task, 1, 300);

}

}

我这里给出了3种实现方案(其实是两种)来实现达到View闪烁的效果。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值