您的位置:首页 > 其它

安卓开发启用线程动态显示和隐藏悬浮控件(ImageButton),点击回到页面顶部

2017-09-11 17:50 489 查看
需求分析:如下图



让上图中绿色向上箭头在点击或滑动屏幕一秒后显示,显示3s后自动隐藏,再次点击或者滑动1s后再次显示,以此类推,并且点击这个箭头的时候要回到页面顶部

实现过程:

acvitity根部局中添加ImageButton控件,默认设置是不显示的,acvitity根部局用ScrollView包裹,确保页面是可以滑动的

<ImageButton
android:id="@+id/IB_top"
android:layout_width="50dp"
android:layout_height="50dp"
android:layout_alignParentBottom="true"
android:layout_alignParentRight="true"
android:layout_marginBottom="80dp"
android:layout_marginRight="@dimen/margin_15dp"
android:background="@drawable/indicator_blue"
android:scaleType="centerInside"
android:src="@drawable/topback"
android:visibility="gone" />


在Java代码中找到并实例化ImageButton和ScrollView,添加点击事件,实现点击按钮返回顶部的功能

IB_top= (ImageButton) findViewById(R.id.IB_top);
sv= (ScrollView) findViewById(R.id.sv);
IB_top.setOnClickListener(this);
、、、
switch (v.getId()) {
case R.id.IB_top://返回顶部按钮
sv.post(new Runnable() {
@Override
public void run() {
sv.fullScroll(ScrollView.FOCUS_UP);
}
});
break;


此处也可以在onResume方法中直接先执行一次,进来时候确保页面在顶部

下边就是控制显示和隐藏控件的方法,重写dispatchTouchEvent方法,用线程实现

private Handler mHandler = new Handler() {
public void handleMessage(Message msg) {
switch (msg.what) {
case MSG_WHAT:
if (countTime > 0) {
countTime--;
if (countTime==2){
IB_top.setVisibility(View.VISIBLE);
}
} else {
if (timer != null) {
timer.cancel();
timer = null;
countTime=3;
IB_top.setVisibility(View.GONE);
}
}
break;
case 1:
if (countTime > 0) {
countTime--;
} else {
if (timer != null) {
timer.cancel();
timer = null;
countTime=3;
IB_top.setVisibility(View.GONE);
}
}
break;
default:
break;
}
}
};

@Override
public boolean dispatchTouchEvent(MotionEvent ev) {

if (timer == null) {
timer = new Timer();
timer.schedule(new TimerTask() {
@Override
public void run() {
mHandler.sendEmptyMessage(MSG_WHAT);
}
}, 800, 1000);
} else {
timer.cancel();
timer = null;
countTime=3;
timer = new Timer();
timer.schedule(new TimerTask() {
@Override
public void run() {
mHandler.sendEmptyMessage(MSG_WHAT);
}
}, 800, 1000);//延时启动0.8s,每隔一秒发送一次,屏幕获取焦点0.8s后显示控件
//            IB_top.setVisibility(View.VISIBLE);
//            return true;
}
//        timer.schedule(task,1000,1000);
return super.dispatchTouchEvent(ev);

}


至此就实现了悬浮按钮的动态显示和隐藏,以及点击回到顶部的功能
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: