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

需求分析:如下图
这里写图片描述
让上图中绿色向上箭头在点击或滑动屏幕一秒后显示,显示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);

    }

至此就实现了悬浮按钮的动态显示和隐藏,以及点击回到顶部的功能

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值