Android studio实现刮刮乐的方法

本文实例为大家分享了Android studio实现刮刮乐的具体代码,供大家参考,具体内容如下

MainActivity

public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); } }

第一种方法:

GuaTwo

public class GuaTwo extends View { /*第一种方法*/ private Path mPath;//手刮动的path,过程 private Paint mOutterPaint;//绘制mPath的画笔 private Canvas mCanvas;//临时画布 private Bitmap mBitmap;//临时图片 //记录用户path每次的开始坐标值 private int mLastX; private int mLastY; private Bitmap mOutterBitmap;//图片遮罩,就是手刮动,要擦掉的那张图 public GuaTwo(Context context) { this(context, null); } public GuaTwo(Context context, AttributeSet attrs) { this(context, attrs, 0); } public GuaTwo(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); init(); } @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { super.onMeasure(widthMeasureSpec, heightMeasureSpec); //获得控件的宽高 int width = getMeasuredWidth(); int height = getMeasuredHeight(); //初始化bitmap mBitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888); mCanvas = new Canvas(mBitmap); //设置画笔属性 setupOutPaint(); mCanvas.drawColor(Color.parseColor("#c0c0c0")); } @Override protected void onDraw(Canvas canvas) { mOutterPaint.setStyle(Paint.Style.STROKE); mOutterPaint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.DST_OUT));//Mode.DST_OUT改模式就类似橡皮檫,这个属性设置是关键 canvas.drawBitmap(mOutterBitmap, 0, 0, null); canvas.drawBitmap(mBitmap, 0, 0, null); mCanvas.drawPath(mPath, mOutterPaint); } @Override public boolean onTouchEvent(MotionEvent event) { int action = event.getAction(); int x = (int) event.getX(); int y = (int) event.getY(); switch (action) { case MotionEvent.ACTION_DOWN://按下 //记录按下的时候的X和Y值,以便于之后移动的时候绘制 mLastX = x; mLastY = y; mPath.moveTo(mLastX, mLastY); break; case MotionEvent.ACTION_MOVE://移动 //拿到用户移动的X绝对值,Y轴绝对值 int dx = Math.abs(x - mLastX); int dy = Math.abs(y - mLastY); //用户滑动超过3像素才会改变,这个可以不做,做只是为了避免很频繁的响应而已。 if (dx > 3 || dy > 3) { mPath.lineTo(x, y); } mLastX = x; mLastY = y; break; } invalidate();//刷新UI return true; } /** * 绘制path(也就是手刮动的path来绘制) 的画笔属性 * 类似橡皮擦 */ private void setupOutPaint() { mOutterPaint.setColor(Color.RED); mOutterPaint.setAntiAlias(true); mOutterPaint.setDither(true); mOutterPaint.setStrokeJoin(Paint.Join.ROUND);//设置圆角 mOutterPaint.setStrokeCap(Paint.Cap.ROUND); mOutterPaint.setStyle(Paint.Style.FILL); mOutterPaint.setStrokeWidth(60);//设置画笔宽度 } /** * 初始化信息 */ private void init() { mOutterPaint = new Paint(); mPath = new Path(); mOutterBitmap = BitmapFactory.decodeResource(getResources(), R.drawable.mein); }

第二种方法:

GuaTwo

private Path mPath;//手刮动的path,过程 private Paint mOutterPaint;//绘制mPath的画笔 private Canvas mCanvas; private Bitmap mBitmap; //记录用户path每次的开始坐标值 private int mLastX; private int mLastY; private Bitmap mOutterBitmap;//图片遮罩,就是手刮动,要擦掉的那张图 private String mText;//刮奖文本信息 private Rect mTextBound; private Paint mBackPaint;//刮奖信息的画笔 public GuaTwo(Context context) { this(context, null); } public GuaTwo(Context context, AttributeSet attrs) { this(context, attrs, 0); } public GuaTwo(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); init(); } @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { super.onMeasure(widthMeasureSpec, heightMeasureSpec); //获得控件的宽高 int width = getMeasuredWidth(); int height = getMeasuredHeight(); //初始化bitmap mBitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888); mCanvas = new Canvas(mBitmap);//用指定的位图构造一个画布来绘制。 //设置画笔属性 setupOutPaint(); setUpBackPaint(); // mCanvas.drawColor(Color.parseColor("#c0c0c0")); mCanvas.drawRoundRect(new RectF(0, 0, width, height), 30, 30, mOutterPaint);//用mOutterPaint画圆角矩形 mCanvas.drawBitmap(mOutterBitmap, null, new Rect(0, 0, width, height), null);//在刚刚画的圆角矩形上面再画一个bitmap图片,让图片大小和圆角矩形大小相关联 } @Override protected void onDraw(Canvas canvas) { mOutterPaint.setStyle(Paint.Style.STROKE); mOutterPaint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.DST_OUT));//Mode.DST_OUT改模式就类似橡皮檫,这个属性设置是关键 canvas.drawText(mText, (getWidth() - mTextBound.width()) / 2, getHeight() / 2 - mTextBound.height() / 2, mBackPaint);//把获奖信息放在正中间 mCanvas.drawPath(mPath, mOutterPaint); canvas.drawBitmap(mBitmap, 0, 0, null); } @Override public boolean onTouchEvent(MotionEvent event) { int action = event.getAction(); int x = (int) event.getX(); int y = (int) event.getY(); switch (action) { case MotionEvent.ACTION_DOWN://按下 //记录按下的时候的X和Y值,以便于之后移动的时候绘制 mLastX = x; mLastY = y; mPath.moveTo(mLastX, mLastY); break; case MotionEvent.ACTION_MOVE://移动 //拿到用户移动的X绝对值,Y轴绝对值 int dx = Math.abs(x - mLastX); int dy = Math.abs(y - mLastY); //用户滑动超过3像素才会改变,这个可以不做,做只是为了避免很频繁的相应而已。 if (dx > 3 || dy > 3) { mPath.lineTo(x, y); } mLastX = x; mLastY = y; break; } invalidate();//刷新UI return true; } private void setUpBackPaint() { mBackPaint.setColor(Color.RED); mBackPaint.setStyle(Paint.Style.FILL); mBackPaint.setTextSize(60); //获得当前画笔绘制文本的宽和高 mBackPaint.getTextBounds(mText, 0, mText.length(), mTextBound); } *//** * 绘制path(也就是手刮动的path来绘制) 的画笔属性 * 类似橡皮擦 *//* private void setupOutPaint() { mOutterPaint.setColor(Color.RED); mOutterPaint.setAntiAlias(true); mOutterPaint.setDither(true); mOutterPaint.setStrokeJoin(Paint.Join.ROUND);//设置圆角 mOutterPaint.setStrokeCap(Paint.Cap.ROUND); mOutterPaint.setStyle(Paint.Style.FILL); mOutterPaint.setStrokeWidth(60);//设置画笔宽度 } *//** * 初始化信息 *//* private void init() { mOutterPaint = new Paint(); mPath = new Path(); mOutterBitmap = BitmapFactory.decodeResource(getResources(), R.drawable.huahua); mText = "您中奖了!"; mTextBound = new Rect(); mBackPaint = new Paint(); }

布局文件

xml文件:

<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/activity_main" android:layout_width="match_parent" android:layout_height="match_parent" android:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" tools:context="com.bwie.test.guaguale.MainActivity"> <com.bwie.test.guaguale.GuaTwo android:layout_width="wrap_content" android:layout_height="wrap_content" /> </RelativeLayout>

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

时间: 2024-11-01 01:36:21

Android studio实现刮刮乐的方法的相关文章

android studio如何去掉自己创建的方法名下面的小波浪线?

问题描述 android studio如何去掉自己创建的方法名下面的小波浪线? android studio如何去掉自己创建的方法名下面的小波浪线?怎么去掉小波浪线??看着好不舒服 解决方案 File-->Settings,在左侧面板选择Editor-->Inspections,右侧找到Spelling选项,将其后面复选框的对勾去掉,然后保存即可. 解决方案二: 因为定义了这个方法却没有用到...? 解决方案三: 在这里解决

Android Studio中引入Lambda表达式的方法

本文介绍的是在Android Studio中引入Lambda表达式的方法,下面话不多说,来看看详细的介绍. 方法如下: 依次点击 [File][Other Settings][Default Project Structure]确保当前项目使用的JDK版本是1.8. 打开项目(Project)的build.gradle,在dependencies节点添加 classpath 'me.tatarka:gradle-retrolambda:3.2.0' 打开项目(Module)的build.grad

Android Studio中使用lambda表达式的方法

1.module的build.gradle里buildTypes中添加: compileOptions { sourceCompatibility JavaVersion.VERSION_1_8 targetCompatibility JavaVersion.VERSION_1_8 } 2.module的build.gradle里defaultConfig中添加: jackOptions.enabled = true 3.注意事项:jack可能会导致中文乱码,所以需要在gradle.proper

Android Studio 报错“app:processDebugResources"解决方法

Android Studio 报错"app:processDebugResources"解决方法 Android Studio项目Build的时候报了这么一个错误: Error:Execution failed for task ':app:processDebugResources'. > com.android.ide.common.process.ProcessException: org.gradle.process.internal.ExecException: Pro

总结Android Studio导入项目的几种方法

本篇教程中使用到的Android Studio版本为1.0, Eclipse ADT版本23.0.4.请尝试更新到该版本. Android Studio默认使用 Gradle 构建项目, Eclipse 默认使用Ant构建项目.建议Android Studio导入项目时,使用 Gradle 构建项目. 导入 Eclipse 项目 本例中,使用到的 Eclipse 项目结构如图:   e-demo 为主项目, appcompat_v7 为 library 项目. 导入 Generate Gradl

解决android studio升级失败提示 Connection failed方法

关于这个问题,查了不少地方,发现解决方法都差不多,但或多或少有些问题或没说清楚.关于在windows系统中的解决方法,基本没什么问题,都是如下修改: 在Android Studio安装目录"/bin/studio.exe.vmoptions"文件中追加以下几行 -Djava.net.preferIPv4Stack=true -Didea.updates.url=http://dl.google.com/android/studio/patches/updates.xml -Didea.

Android Studio导入Project与Module的方法及实例

Gradle Project项目.Module模块导入 最近看到网上很多人在抱怨,Android Studio很难导入github上下载下来的一些项目,主要包括: 1.导入就在下载Gradle 2.根本导不进 下面我分2部分来讲解正确的导入姿势: 1.导入完整的Github Project 我们在github上找一个项目 工程目录如上,里面的东西其实分为2部分,工程相关和项目相关 工程相关用于配置整个项目的编译环境和依赖,项目相关就是你的代码和配置文件啦 我们先来看工程相关,他包含这样几个文件夹

Android Studio导入项目非常慢的解决方法_Android

Android Studio原生支持使用Gradle来构建项目,使用动态语言Groovy定义项目构建的过程,避免了build.xml文件繁琐的定义. 然而使用的时候,却有着巨大的缺陷.由于Android Studio在升级的时候,可能会伴随着Gradle版本的升级,Gradle就会产生若干的版本. 为了保证程序不会因为Gradle版本不同导致问题,又产生了Gradle Wrapper,它的作用就是让项目绑定一个Gradle版本,当我们导入项目时,会自动下载相应的Gradle版本. 问题来了 这就

Android Studio导入项目非常慢的解决方法

Android Studio原生支持使用Gradle来构建项目,使用动态语言Groovy定义项目构建的过程,避免了build.xml文件繁琐的定义. 然而使用的时候,却有着巨大的缺陷.由于Android Studio在升级的时候,可能会伴随着Gradle版本的升级,Gradle就会产生若干的版本. 为了保证程序不会因为Gradle版本不同导致问题,又产生了Gradle Wrapper,它的作用就是让项目绑定一个Gradle版本,当我们导入项目时,会自动下载相应的Gradle版本. 问题来了 这就

asynctask-AsyncTask中的execute方法在android studio中报错

问题描述 AsyncTask中的execute方法在android studio中报错 我的android studio中的AsyncTask的execute方法在编辑框中飘红报错, 提示"Cannot resolve method 'execute(java.lang.string)'",类名那里也会有红色下划线报错.但是不影响程序,程序可以正常运行.总觉得这样看着不舒服 解决方案 贴出整个代码,可能是你的参数类型和后面继承AsyncTask指定的不一样导致的,