iis服务器助手广告广告
返回顶部
首页 > 资讯 > 移动开发 >安卓(Android)实现3DTouch效果
  • 917
分享到

安卓(Android)实现3DTouch效果

3dtouchAndroid 2022-06-06 07:06:07 917人浏览 泡泡鱼
摘要

本篇博客要做的效果图: 来个低质量动图: 这个动图效果不是很好,实际上模糊效果应该是像上面第一张图那样的,后面会放出代码,有兴趣的可以试着运行一下看看效果。  先

本篇博客要做的效果图:

来个低质量动图:

这个动图效果不是很好,实际上模糊效果应该是像上面第一张图那样的,后面会放出代码,有兴趣的可以试着运行一下看看效果。 

先说一下思路,我们要实现这个效果其实只需要掌握几个东西:

      1、屏幕截图

      2、模糊高斯模糊)

      3、添加视图

      4、弹出动画

      5、处理长按事件

      6、优化(模糊速度和强度)

流程:当用户长按一个

Item
的时候,我们先截取一张当前屏幕的图片,接着将这张图片进行压缩后再进行高斯模糊,再覆盖在整个布局上面(包括覆盖Toolbar),这样界面模糊的效果就出来了。接着我们动态的向界面添加一个
CardView
来呈现我们的
Item
布局,这个
CardView
要出现在我们点击的对应的Item上。最后添加一个对应3D Touch弹出的动画即可。 

接下来我们一步一步的完成整个流程:

① 屏幕截图

这一部分相对比较简单,因为我们要得到当前屏幕显示内容的

Bitmap
是有现成方法的,代码如下:


  private Bitmap getScreenImage() { // 截取一张屏幕的图片
    View view = root;
    view.setBackgroundColor(Color.WHITE);
    view.setDrawinGCacheEnabled(true);
    view.buildDrawingCache();
    Bitmap bitmap = Bitmap.createBitmap(view.getDrawingCache(), 0, 0, view.getWidth(), view
        .getHeight());
    view.destroyDrawingCache();
    return bitmap;
  }

先说一下布局,这里的布局文件如下所示:


<?xml version="1.0" encoding="utf-8"?>
<FrameLayout
  xmlns:Android="Http://schemas.android.com/apk/res/android"
  xmlns:app="http://schemas.android.com/apk/res-auto"
  xmlns:tools="http://schemas.android.com/tools"
  android:id="@+id/activity_main"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  tools:context="com.fndroid.threedtouchdemo.MainActivity">
  <LinearLayout
    android:id="@+id/root"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">
    <android.support.v7.widget.Toolbar
      android:id="@+id/toolbar"
      android:layout_width="match_parent"
      android:layout_height="?attr/actionBarSize"
      android:background="@color/colorPrimary"
      app:title="@string/app_name"
      app:titleTextColor="#fff"/>
    <ListView
      android:id="@+id/lv"
      android:layout_width="match_parent"
      android:layout_height="match_parent"
      tools:listitem="@layout/item"/>
  </LinearLayout>
  <ImageView
    android:id="@+id/cover"
    android:layout_width="match_parent"
    android:layout_height="match_parent"/>
  <android.support.v7.widget.CardView
    android:id="@+id/cv"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:translationZ="5dp"
    app:cardCornerRadius="10dp"/>
</FrameLayout>

可以看到我们最外层用了一个

FrameLayout
,原因是我们需要往整个布局中覆盖一个高斯模糊了的截图,可以看到最下面的
ImageView
就是用来做模糊效果的,最开始我们只需要给它的
ImageAlpha
设置为0让其透明即可。最下面的
CardView
则是弹出的控件,这个等下再说。我们截图的
root
FrameLayout
下的
LinearLayout
,因为我们需要让
ToolBar
也模糊化。 

② 高斯模糊

这个在我的上一篇博客--动态高斯模糊怎么做中已经说过了,可以进行参考,这个给出对应的代码:


  private Bitmap blur(Bitmap bitmap, float radius) {
    Bitmap output = Bitmap.createBitmap(bitmap); // 创建输出图片
    RenderScript rs = RenderScript.create(this); // 构建一个RenderScript对象
    ScriptIntrinsicBlur gaussianBlue = ScriptIntrinsicBlur.create(rs, Element.U8_4(rs)); //
    // 创建高斯模糊脚本
    Allocation allIn = Allocation.createFromBitmap(rs, bitmap); // 开辟输入内存
    Allocation allOut = Allocation.createFromBitmap(rs, output); // 开辟输出内存
    gaussianBlue.setRadius(radius); // 设置模糊半径,范围0f<radius<=25f
    gaussianBlue.setInput(allIn); // 设置输入内存
    gaussianBlue.forEach(allOut); // 模糊编码,并将内存填入输出内存
    allOut.copyTo(output); // 将输出内存编码为Bitmap,图片大小必须注意
    rs.destroy(); // 关闭RenderScript对象,api>=23则使用rs.releaseAllContexts()
    return output;
  }

配置对应Module的build.gradle文件:


  defaultConfig {
    ...
    renderscriptTargetApi 18
    renderscriptSupportModeEnabled true
  }

 ③ 弹出视图

这个视图我们需要将

Item
View
添加到
CardView
中,并且让
CardView
的位置在对应
Item
位置之上。


  // 显示对应的卡片
  private void showView(int position, View view){
    newView = LayoutInflater.from(this).inflate(R.layout.item, null); // 加载Itme的布局
    TextView tv = (TextView) newView.findViewById(R.id.item_tv); // 获取对应控件
    tv.setText(data.get(position).get("name")); // 将Item对应控件的值设置回去
    newView.setBackgroundColor(Color.WHITE);
    // 设置卡片的样式,位置通过margintop来计算
    FrameLayout.LayoutParams params = new FrameLayout.LayoutParams(view.getWidth() - 30, view.getHeight());
    params.topMargin = (int) (view.getY() + mToolbar.getHeight()); // 卡片的marginTop设置为item的Y加上toolbar的高度
    params.leftMargin = 15;
    params.rightMargin = 15;
    mCardView.setVisibility(View.VISIBLE);
    mCardView.setLayoutParams(params);
    mCardView.addView(newView, view.getLayoutParams()); // 把View加载进CardView,并设置样式为item样式
    startAnimate(mCardView); // 播放动画
  }

这里不能直接把

item
view
加载进
CardView
中,因为
item
View
已经有父布局了,会抛异常。解决办法是重新根据布局映射一个,然后填充数据进去。接着设定卡片的位置信息和大小信息,因为我们要让卡片显示在对应
Item
上面。 

④ 弹出动画

这是比较简单的部分了,我们直接使用

PropertyValuesHolder
来做一个弹出和收缩的动,因为我们需要同时缩放X和Y,当然也可以用其他方法,代码如下:


  private void startAnimate(CardView cardView) {
    PropertyValuesHolder pyhScaleX = PropertyValuesHolder.ofFloat("scaleX", 0.1f, 1.05f);
    PropertyValuesHolder pyhScaleY = PropertyValuesHolder.ofFloat("scaleY", 0.1f, 1.05f);
    ObjectAnimator animator_out = ObjectAnimator.ofPropertyValuesHolder(mCardView, pyhScaleX,
        pyhScaleY); // 同时缩放X和Y
    animator_out.setInterpolator(new AccelerateDecelerateInterpolator());
    animator_out.setDuration(350);
    PropertyValuesHolder pyhScaleX2 = PropertyValuesHolder.ofFloat("scaleX", 1.05f, 1f);
    PropertyValuesHolder pyhScaleY2 = PropertyValuesHolder.ofFloat("scaleY", 1.05f, 1f);
    ObjectAnimator animator_in = ObjectAnimator.ofPropertyValuesHolder(mCardView, pyhScaleX2,
        pyhScaleY2);
    animator_in.setInterpolator(new AccelerateDecelerateInterpolator());
    animator_in.setDuration(100);
    AnimatorSet animatorSet = new AnimatorSet();
    animatorSet.playSequentially(animator_out, animator_in); // 按顺序执行两个动画
    animatorSet.start();
  }

⑤ 监听长按事件

因为这里只是使用了

ListView
来简化这个内容,可以直接通过已有监听器来实现:


@Override
  public boolean onItemLongClick(AdapterView<?> parent, View view, int position, long id) {
    mCover.setImageBitmap(blur(blur(getScreenImage(), 25f),25f)); // 对截取的图片两次高斯模糊
    mCover.setVisibility(View.VISIBLE);
    mCover.setImageAlpha(0);
    new Thread(new Runnable() {
      int progress = 50;
      @Override
      public void run() {
        while (progress < 255) {
          try {
            Thread.sleep(1);
          } catch (InterruptedException e) {
            e.printStackTrace();
          }
          Message msg = new Message();
          msg.obj = progress++;
          mHandler.sendMessage(msg);
        }
      }
    }).start();
    showView(position, view);
    return true;
  }

这里的第3行中调用了两次

blur
方法来对图片进行高斯模糊 ,如果看过上一篇博客,每次高斯模糊的最大模糊半径是25,如果要做到向iOS那也的模糊效果,25是不够的,所以可以对模糊出来的图片再模糊化一次,对比图(左边为2次模糊,右边1次):

   

 ⑥ 优化

但是实际上,对于一个分辨率比较高的手机,截取的屏幕分辨率较大的情况下,通过多次模糊这样的做法也是不推荐的。这里可以试想一下,假设我们先获取到截屏,接着是否能将这个截取的图片先进行压缩,毕竟后期还是需要模糊的,也就是这个图片被压缩了其实并不影响我们进行模糊(因为到最后都是模糊了)。实际上,当我们进行图片压缩的之后,会发现在相同模糊半径之下,图片的模糊效果不同了,如下两图:

   

原因是:高斯模糊采用的算法中确定一个点的颜色是通过这个点附近的其他点来求平均(带权)得到的,而取附近多是个像素点,就是通过模糊半径来确定。当图片被压缩之后,相同模糊半径下,每次取样的区域就变大了,所以模糊强度就更大了。

这样,我们就可以不需要进行多次模糊,并且,压缩图片后,总像素点变少,模糊速度也就变得更快了。

这里同样给出图片压缩的代码:


  private Bitmap getSmallSizeBitmap(Bitmap source, float percent) {
    if (percent > 1 || percent <= 0) {
      throw new IllegalArgumentException("percent must be > 1 and <= 0");
    }
    Matrix matrix = new Matrix();
    matrix.setScale(percent, percent);
    return Bitmap.createBitmap(source, 0, 0, source.getWidth(), source.getHeight(), matrix, true);
  }

总结

以上就是在安卓(Android)实现3DTouch效果的全部内容,刚兴趣的可以自己动手实践起来,希望本文的内容对大家能有所帮助。

您可能感兴趣的文章:Android 3D旋转动画效果实现分解Android高级图片滚动控件实现3D版图片轮播器Android酷炫动画效果之3D星体旋转效果Android编程实现3D立体旋转效果的实例代码Android动画之3D翻转效果实现函数分析Android开发 OpenGL ES绘制3D 图形实例详解Android 使用Gallery实现3D相册(附效果图+Demo源码)Android使用Rotate3dAnimation实现3D旋转动画效果的实例代码


--结束END--

本文标题: 安卓(Android)实现3DTouch效果

本文链接: https://www.lsjlt.com/news/24327.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 安卓开发实现阴影效果
    问题背景 安卓日常学习和开发过程中,经常会有实现组件和布局阴影效果的场景,本文将介绍安卓开发过程实现阴影效果的几种方案。 问题分析 (1)elevation的方式 Material Design提供了...
    99+
    2023-09-07
    android
  • android viewpager实现轮播效果
    本文是基于ViewPager实现的无限自动轮播banner,供大家参考,具体内容如下 分为四步去实现: 第一步是有限手动轮播; 第二步是无限轮播; 第三步是自动轮播; 第四步是指示...
    99+
    2024-04-02
  • Android实现滤镜效果ColorMatrix
    本文实例为大家分享了Android实现滤镜效果的具体代码,供大家参考,具体内容如下 1.效果图 2.矩阵算法 package net.surina.myapplication1...
    99+
    2024-04-02
  • Android实现轮播图效果
    本文实例为大家分享了Android实现轮播图效果的具体代码,供大家参考,具体内容如下 1.代码放在LinearLayout中, <com.jude.rollviewpage...
    99+
    2024-04-02
  • Android实现仪表盘效果
    本文实例为大家分享了Android实现仪表盘效果的具体代码,供大家参考,具体内容如下 仪表盘效果,圆弧可变色,效果图如下: 通过自定义view实现,代码如下: public c...
    99+
    2024-04-02
  • Android实现悬浮窗效果
    本文实例为大家分享了Android实现悬浮窗效果的具体代码,供大家参考,具体内容如下 一、权限: <uses-permission android:name="android....
    99+
    2024-04-02
  • android gallery3D效果怎么实现
    要实现Android中的Gallery3D效果,可以使用ViewPager和自定义的PagerTransformer来实现。首先,需...
    99+
    2023-08-31
    android
  • Android实现梯形TextView效果
    目录效果图:自定义代码实现逻辑:要点分析 1.背景与文本内容的绘制 2.梯形范围内外的点击事件处理 3.其它自定义属性 效果图: 自定义代码实现逻辑: public class...
    99+
    2024-04-02
  • Android实现Window弹窗效果
    本文实例为大家分享了Android实现Window弹窗效果的具体代码,供大家参考,具体内容如下 效果图 第一步 准备弹窗的布局,新建XML文件 photo_window &l...
    99+
    2024-04-02
  • Android studio实现菜单效果
    本文实例为大家分享了Android studio实现菜单效果的具体代码,供大家参考,具体内容如下 一、onCreateOptionsMenu() 首先在res目录下新建一个menu文...
    99+
    2024-04-02
  • Android实现3D滚动效果
    先上效果图 下载链接http://down.51cto.com/data/1076318...
    99+
    2023-01-31
    效果 Android
  • Android实现顶部悬浮效果
    本文实例为大家分享了Android实现顶部悬浮效果的具体代码,供大家参考,具体内容如下效果图 布局<?xml version="1.0" encoding="utf-8"?><android.su...
    99+
    2023-05-30
    android 顶部悬浮 roi
  • Android Studio实现进度条效果
    本文实例为大家分享了Android Studio实现进度条效果的具体代码,供大家参考,具体内容如下 实验作业 要求一个进度条,进度随机 效果图 xml代码 <?x...
    99+
    2024-04-02
  • android实现多点触摸效果
    本文实例为大家分享了android实现多点触摸效果的具体代码,供大家参考,具体内容如下 1.获取点击xy轴的下标,实现触摸效果。 获取XY画一个圆并且自动从下变大,直到消失不见。 效...
    99+
    2024-04-02
  • Android实现文字消除效果
    今天和大家分享一个如何从右到左消除文本的动画。 先看效果图: 由于项目和语音识别相关,有时候人在不经意间交流的无效音频会被识别出来,并展示于界面,为了美观,客户要求我们将这些无效的...
    99+
    2024-04-02
  • Android实现控件拖动效果
    本文实例为大家分享了Android实现控件拖动效果的具体代码,供大家参考,具体内容如下 1.今天突然想到做个实现个控件拖动效果,就来试试,一查原来还是很简单的 2.原理就是实现OnT...
    99+
    2024-04-02
  • Android实现越界回弹效果
    本文实例为大家分享了Android实现越界回弹效果的具体代码,供大家参考,具体内容如下 1、直接上图: 2、直接上代码 public class DampingReboundLay...
    99+
    2024-04-02
  • Android实现视图轮播效果
    最近接手了一个需求,要求实现,叮咚买菜。 秒杀位置的轮播 拆解 通过观察发现其实还是挺简单,大致分为 1、商品图片的上下轮播 2、价格布局渐隐渐现 在android上实现布局轮播,...
    99+
    2024-04-02
  • Android怎么实现阴影效果
    这篇文章主要介绍了Android怎么实现阴影效果的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Android怎么实现阴影效果文章都会有所收获,下面我们一起来看看吧。实现形式elevationMaterial D...
    99+
    2023-07-02
  • Android实现京东首页效果
    本文实例为大家分享了Android实现京东首页效果的具体代码,供大家参考,具体内容如下 1.效果图: 2.布局 源码链接 <?xml version="1.0" ...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作