Android使用Canvas对象实现刮刮乐效果

作者:赵凯强 时间:2021-11-27 02:53:36 

在淘宝、京东等电商举办活动的时候,经常可以看到在移动客户端推出的各种刮奖活动,而这种活动也受到了很多人的喜爱。从客户端的体验来说,这种效果应该是通过网页来实现的,那么,我们使用Android的自带控件能不能实现这种刮刮乐的效果呢?当然可以,本篇文章将介绍使用Canvas这个对象,如何实现“刮刮乐”的效果。

先看效果图

Android使用Canvas对象实现刮刮乐效果

下面我们看一下如何使用代码实现

布局文件


<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:layout_height="match_parent" >

<ImageView
   android:id="@+id/after"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:src="@drawable/a" />

<ImageView
   android:id="@+id/before"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:src="@drawable/b" />

</FrameLayout>

Activity代码


public class MainActivity extends Activity implements OnTouchListener {

private ImageView imgafter;
 private ImageView imgbefore;
 private Canvas canvas;
 private Paint paint;
 private Bitmap bitmap;
 private Bitmap before;
 private Bitmap after;

@Override
 protected void onCreate(Bundle savedInstanceState) {
   super.onCreate(savedInstanceState);
   setContentView(R.layout.activity_main);

imgafter = (ImageView) findViewById(R.id.after);
   imgbefore = (ImageView) findViewById(R.id.before);

// 获得图片
   after = BitmapFactory.decodeResource(getResources(), R.drawable.a);
   before = BitmapFactory.decodeResource(getResources(), R.drawable.b);

imgafter.setImageBitmap(after);
   imgbefore.setImageBitmap(before);
   // 创建可以修改的空白的bitmap
   bitmap = Bitmap.createBitmap(before.getWidth(), before.getHeight(),
       before.getConfig());
   imgbefore.setOnTouchListener(this);
   paint = new Paint();
   paint.setStrokeWidth(5);
   paint.setColor(Color.BLACK);
   // 创建画布
   canvas = new Canvas(bitmap);
   canvas.drawBitmap(before, new Matrix(), paint);
 }

@Override
 public boolean onTouch(View arg0, MotionEvent event) {
   switch (event.getAction()) {
   case MotionEvent.ACTION_MOVE:
     int newX = (int) event.getX();
     int newY = (int) event.getY();
     // 将滑过的地方变为透明
     for (int i = -10; i < 10; i++) {
       for (int j = -10; j < 10; j++) {
         if ((i + newX) >= before.getWidth()
             || j + newY >= before.getHeight() || i + newX < 0
             || j + newY < 0) {
           return false;
         }
         bitmap.setPixel(i + newX, j + newY, Color.TRANSPARENT);
       }
     }
     imgbefore.setImageBitmap(bitmap);
     break;
   }
   return true;
 }
}

可以看到,代码很简单,几十行代码就实现了简单的“刮刮乐”的效果。

原理是这样的,一开始两张图片重叠,显示的还没有刮开的效果。

在Activity的onTouch方法中,我们对滑动事件进行监听,当用户用手指滑动屏幕的时候,我们将滑过的画布部分的颜色设置为透明,同时,把改变之后的bitmap对象设置为ImageView的背景,这样,隐藏在后面的图片就显示出来了,也就实现了刮刮乐的效果。

来源:https://blog.csdn.net/zhaokaiqiang1992/article/details/31789381

标签:Android,Canvas,刮刮乐
0
投稿

猜你喜欢

  • Spring中ApplicationContextAware的使用方法详解

    2023-12-25 07:01:33
  • Android自定义表格控件满足人们对视觉的需求

    2023-10-13 13:35:28
  • C++作用域与函数重载的实现

    2022-04-30 06:28:30
  • C#模式画刷HatchBrush用法实例

    2021-10-01 08:59:45
  • spring cloud gateway中如何读取请求参数

    2021-08-19 16:19:02
  • 详谈C++引用&和指针在作为形参时的区别

    2023-12-13 16:50:49
  • 一文掌握Spring的创建与使用

    2022-01-24 19:28:38
  • java并发编程之深入理解Synchronized的使用

    2023-10-11 09:21:13
  • Java面向对象之猜拳游戏

    2022-10-29 21:26:45
  • SpringMVC MVC架构与Servlet使用详解

    2023-10-10 15:25:02
  • Java JUC中操作List安全类的集合案例

    2022-10-28 11:09:31
  • idea项目的左侧目录没了如何设置

    2022-03-21 15:45:43
  • C#使用BinaryFormatter类、ISerializable接口、XmlSerializer类进行序列化和反序列化

    2023-01-16 02:11:54
  • Android线程管理之ActivityThread

    2022-05-08 07:48:35
  • Java实现手写线程池的示例代码

    2022-01-09 13:08:24
  • Java反射根据不同方法名动态调用不同的方法(实例)

    2022-05-08 00:51:47
  • @Autowired注解在抽象类中失效的原因及解决

    2021-07-15 06:12:04
  • Java中抓取 Thread Dumps 的方式汇总

    2021-08-09 23:20:26
  • Java 数据结构进阶二叉树题集下

    2022-07-11 19:16:18
  • IDEA安装阿里巴巴编码规范插件的两种方式详解(在线安装和离线安装)

    2022-07-23 19:18:54
  • asp之家 软件编程 m.aspxhome.com