Android实现桌面悬浮小火箭效果

本文实例为大家分享了Android实现悬浮小火箭效果的具体代码,供大家参考,具体内容如下

思路

使用serivce在后台启动小火箭
小火箭使用windowmanager实现。
用ontoch监听实现小火箭的拖拽。

代码实现

public class RocketService extends Service {

   private WindowManager mWM;
   private View view;
   private int startX ;
   private int startY ;
   private LayoutParams params;

   @Override
   public IBinder onBind(Intent intent) {
      return null ;
   }

   @Override
   public void onCreate() {
      super .onCreate();
     System. out .println("服务创建。。。。" );
      mWM = (WindowManager) getSystemService(WINDOW_SERVICE );
      winWidth = mWM.getDefaultDisplay(). getWidth();
      winHeight = mWM .getDefaultDisplay().getHeight ();

      params = new WindowManager.LayoutParams();
      params. height = WindowManager.LayoutParams.WRAP_CONTENT ;
      params. width = WindowManager.LayoutParams.WRAP_CONTENT ;
      params. flags = WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON
          | WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE ;
      params. format = PixelFormat. TRANSLUCENT ;
      params. type = WindowManager.LayoutParams.TYPE_PHONE ;
      params. gravity = Gravity. LEFT + Gravity. TOP;

      view = LayoutInflater.from( this).inflate(R.layout. rocket , null );
      //拿到 imageview,设置帧动画
     ImageView ivRocket = (ImageView) view .findViewById(R.id. rocket);
     ivRocket.setImageResource(R.drawable. rocket );
     AnimationDrawable drawable = (AnimationDrawable) ivRocket.getDrawable();
     drawable.start();
      mWM.addView( view, params);

      // 设置view的触摸事件,让它可以被拖拽
      view.setOnTouchListener( new OnTouchListener() {

        @Override
        public boolean onTouch(View v, MotionEvent event) {
          switch (event.getAction()) {
          case MotionEvent. ACTION_DOWN:
             startX = ( int ) event.getRawX();
             startY = ( int ) event.getRawY();
             break ;
          case MotionEvent. ACTION_MOVE:
             int dx = (int ) (event.getRawX() - startX );
             int dy = (int ) (event.getRawY() - startY );
             // 更新浮窗位置
             params. x += dx;
             params. y += dy;

             // 限制窗口坐标不超过屏幕
             if (params .x < 0) {
               params. x = 0;
            }

             if (params .x > winWidth - view .getWidth()) {
               params. x = winWidth - view .getWidth();
            }

             if (params .y < 0) {
               params. y = 0;
            }

             if (params .y > winHeight - view .getHeight()) {
               params. y = winHeight - view .getHeight();
            }

             mWM.updateViewLayout( view, params );
             startX = ( int ) event.getRawX();
             startY = ( int ) event.getRawY();
             break ;
          case MotionEvent. ACTION_UP:
             // 手指抬起起,需要发射火箭,限定发射火箭的范围
             if (params .x > 0 && params. x < winWidth
                 && params. y > winHeight - 500) {
               sendRocket();
            }
             break ;
          }

          return true ;// 不再把事件传递给onClick处理
       }

     });
   }

   private Handler mHandler = new Handler() {
      @Override
      public void handleMessage(Message msg) {
          int y = msg.arg1 ;
          params. y = y;
          mWM.updateViewLayout( view, params);
     }
   };
   private int winWidth ;
   private int winHeight ;

   // 发射火箭
   private void sendRocket() {
      // 用子线程更新y轴
      new Thread(new Runnable() {

        @Override
        public void run() {
          int pos = 1000;
          for (int i=0; i <= 10; i++) {
               int y = pos-100*i;
               //休眠100ms发消息
               try {
                 Thread. sleep(100);
               } catch (InterruptedException e) {
                  // TODO Auto-generated catch block
                 e.printStackTrace();
               }

               Message msg = Message.obtain();
               msg. arg1 = y;
               mHandler.sendMessage(msg);
          }
       }
     }).start();
   }

   @Override
   public void onDestroy() {
      // TODO Auto-generated method stub
      super .onDestroy();
      if (mWM != null && view != null) {
        mWM.removeView( view);
        view = null ;
     }

   }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android实战教程第十篇仿腾讯手机助手小火箭发射效果

    之前对系统自带的土司的源码做了简要分析,见博客:点击打开链接 这一篇给一个小案例,自定义土司,模拟腾讯卫士的小火箭发射.如果想要迅速看懂代码,建议先去看一下上篇介绍点击打开链接 首先,定义一个服务,在这个服务里面,完成土司的创建(小火箭布局创建),烟的效果属于动画播放,而且要依托一个activity.(这个activity要定义为透明状态) 定义烟的activity的布局文件 <?xml version="1.0" encoding="utf-8"?>

  • Android实现桌面悬浮小火箭效果

    本文实例为大家分享了Android实现悬浮小火箭效果的具体代码,供大家参考,具体内容如下 思路 使用serivce在后台启动小火箭 小火箭使用windowmanager实现. 用ontoch监听实现小火箭的拖拽. 代码实现 public class RocketService extends Service { private WindowManager mWM; private View view; private int startX ; private int startY ; priva

  • Android实现QQ手机管家悬浮小火箭效果

    今天是2013年的最后一天了,这里首先提前祝大家新年快乐!同时,本篇文章也是我今年的最后一篇文章了,因此我想要让它尽量有点特殊性,比起平时的文章要多一些特色.记得在今年年初的时候,我写的第一篇文章是模仿360手机卫士的桌面悬浮窗效果,那么为了能够首尾呼应,今年的最后一篇文章就同样还是来实现桌面悬浮窗的效果吧,当然效果将会更加高级. 相信用过QQ手机管家的朋友们都会知道它有一个小火箭加速的功能,将小火箭拖动到火箭发射台上发射就会出现一个火箭升空的动画,那么今天我们就来模仿着实现一下这个效果吧. 这

  • Android实现桌面悬浮窗、蒙板效果实例代码

    现在很多安全类的软件,比如360手机助手,百度手机助手等等,都有一个悬浮窗,可以飘浮在桌面上,方便用户使用一些常用的操作. 今天这篇文章,就是介绍如何实现桌面悬浮窗效果的. 首先,看一下效果图. 悬浮窗一共分为两个部分,一个是平常显示的小窗口,另外一个是点击小窗口显示出来的二级悬浮窗口. 首先,先看一下这个项目的目录结构. 最关键的就是红框内的四个类. 首先,FloatWindowService是一个后台的服务类,主要负责在后台不断的刷新桌面上的小悬浮窗口,否则会导致更换界面之后,悬浮窗口也会随

  • 基于Android实现桌面悬浮清内存app概述

    今天闲来无事写了一个清内存的小东西,类似360,在桌面上悬浮,点击后清除后台无用程序,清除后台程序是通过调用ActivityManger.killBackgroundProcesses的方式来进行的,这样的方式有个不好的地方,就是重要性级别设置的高的应用杀不掉.关键代码如下所示 ActivityManager mActivityManager = MyManager.getActivityManager(mContext); List<ActivityManager.RunningAppProc

  • android中RecyclerView悬浮吸顶效果

    MultiType-Adapter打造悬浮吸顶效果 注:当前版本只适合配合RecyclerView快速打造一款 展示UI 悬浮吸顶效果,如 通讯录效果,由于实现机制的原因,暂时不支持触摸事件. MultiType-Adapter介绍地址:MultiType-Adapter 是一款轻量级支持多数据类型的 RecyclerView 适配器; 使用简单,完全解耦; 悬浮吸顶效果 ```groovy // root build.gradle repositories { jcenter() maven

  • 详解android使用ItemDecoration 悬浮导航栏效果

    开始逐渐领略到ItemDecoration的美~ 今天让我 使用 ItemDecoration 来完成 可推动的悬浮导航栏的效果,最终实现的效果如下图: 具体实现步骤如下: 根据我前面的文章所讲的RecyclerView的基本使用,我们先来完成基本的recyclerView: 第一步:布局里写一个RecyclerView 第二步:实例化 recyclerView = (RecyclerView) findViewById(R.id.recyclerView); 第三步:获取所需的数据 (这里我们

  • android桌面悬浮窗显示录屏时间控制效果

    本文实例为大家分享了android桌面悬浮窗,实现录屏时间控制显示效果的具体代码,供大家参考,具体内容如下 悬浮窗效果如上图所示: 很简单的一个布局直接上代码 悬浮窗布局如下record_screen_time_float.xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/an

  • Android实现仿360桌面悬浮清理内存

    今天闲来无事写了一个清内存的小东西,类似360,在桌面上悬浮,点击后清除后台无用程序,清除后台程序是通过调用ActivityManger.killBackgroundProcesses的方式来进行的,这样的方式有个不好的地方,就是重要性级别设置的高的应用杀不掉.关键代码如下所示 ActivityManager mActivityManager = MyManager.getActivityManager(mContext); List<ActivityManager.RunningAppProc

  • Android RecyclerView实现悬浮吸顶、分隔线、到底提示效果

    本文中所有效果通过ItemDecoration实现,通过此实现的可以与业务解耦,让RecyclerView的模板更加简洁,不关心任何辅助性ui,github地址 一.顶部吸附效果图 二.顶部不吸附效果图 三.不满一屏效果 四.核心实现点 1.为什么通过ItemDecoration能够实现,原理? ①通过getItemOffsets()方法获取当前模板view的left.top.right.bottom边距,这些留出的间距用于绘制这些辅助性ui. // RecyclerView的measure c

随机推荐