Android studio實(shí)現(xiàn)刮刮樂(lè)的方法
本文實(shí)例為大家分享了Android studio實(shí)現(xiàn)刮刮樂(lè)的具體代碼,供大家參考,具體內(nèi)容如下
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;//手刮動(dòng)的path,過(guò)程
private Paint mOutterPaint;//繪制mPath的畫(huà)筆
private Canvas mCanvas;//臨時(shí)畫(huà)布
private Bitmap mBitmap;//臨時(shí)圖片
//記錄用戶path每次的開(kāi)始坐標(biāo)值
private int mLastX;
private int mLastY;
private Bitmap mOutterBitmap;//圖片遮罩,就是手刮動(dòng),要擦掉的那張圖
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);
//設(shè)置畫(huà)筆屬性
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改模式就類似橡皮檫,這個(gè)屬性設(shè)置是關(guān)鍵
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://按下
//記錄按下的時(shí)候的X和Y值,以便于之后移動(dòng)的時(shí)候繪制
mLastX = x;
mLastY = y;
mPath.moveTo(mLastX, mLastY);
break;
case MotionEvent.ACTION_MOVE://移動(dòng)
//拿到用戶移動(dòng)的X絕對(duì)值,Y軸絕對(duì)值
int dx = Math.abs(x - mLastX);
int dy = Math.abs(y - mLastY);
//用戶滑動(dòng)超過(guò)3像素才會(huì)改變,這個(gè)可以不做,做只是為了避免很頻繁的響應(yīng)而已。
if (dx > 3 || dy > 3) {
mPath.lineTo(x, y);
}
mLastX = x;
mLastY = y;
break;
}
invalidate();//刷新UI
return true;
}
/**
* 繪制path(也就是手刮動(dòng)的path來(lái)繪制) 的畫(huà)筆屬性
* 類似橡皮擦
*/
private void setupOutPaint() {
mOutterPaint.setColor(Color.RED);
mOutterPaint.setAntiAlias(true);
mOutterPaint.setDither(true);
mOutterPaint.setStrokeJoin(Paint.Join.ROUND);//設(shè)置圓角
mOutterPaint.setStrokeCap(Paint.Cap.ROUND);
mOutterPaint.setStyle(Paint.Style.FILL);
mOutterPaint.setStrokeWidth(60);//設(shè)置畫(huà)筆寬度
}
/**
* 初始化信息
*/
private void init() {
mOutterPaint = new Paint();
mPath = new Path();
mOutterBitmap = BitmapFactory.decodeResource(getResources(),
R.drawable.mein);
}
第二種方法:
GuaTwo
private Path mPath;//手刮動(dòng)的path,過(guò)程
private Paint mOutterPaint;//繪制mPath的畫(huà)筆
private Canvas mCanvas;
private Bitmap mBitmap;
//記錄用戶path每次的開(kāi)始坐標(biāo)值
private int mLastX;
private int mLastY;
private Bitmap mOutterBitmap;//圖片遮罩,就是手刮動(dòng),要擦掉的那張圖
private String mText;//刮獎(jiǎng)文本信息
private Rect mTextBound;
private Paint mBackPaint;//刮獎(jiǎng)信息的畫(huà)筆
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);//用指定的位圖構(gòu)造一個(gè)畫(huà)布來(lái)繪制。
//設(shè)置畫(huà)筆屬性
setupOutPaint();
setUpBackPaint();
// mCanvas.drawColor(Color.parseColor("#c0c0c0"));
mCanvas.drawRoundRect(new RectF(0, 0, width, height), 30, 30,
mOutterPaint);//用mOutterPaint畫(huà)圓角矩形
mCanvas.drawBitmap(mOutterBitmap, null, new Rect(0, 0, width, height),
null);//在剛剛畫(huà)的圓角矩形上面再畫(huà)一個(gè)bitmap圖片,讓圖片大小和圓角矩形大小相關(guān)聯(lián)
}
@Override
protected void onDraw(Canvas canvas) {
mOutterPaint.setStyle(Paint.Style.STROKE);
mOutterPaint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.DST_OUT));//Mode.DST_OUT改模式就類似橡皮檫,這個(gè)屬性設(shè)置是關(guān)鍵
canvas.drawText(mText, (getWidth() - mTextBound.width()) / 2, getHeight() / 2 - mTextBound.height() / 2, mBackPaint);//把獲獎(jiǎng)信息放在正中間
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://按下
//記錄按下的時(shí)候的X和Y值,以便于之后移動(dòng)的時(shí)候繪制
mLastX = x;
mLastY = y;
mPath.moveTo(mLastX, mLastY);
break;
case MotionEvent.ACTION_MOVE://移動(dòng)
//拿到用戶移動(dòng)的X絕對(duì)值,Y軸絕對(duì)值
int dx = Math.abs(x - mLastX);
int dy = Math.abs(y - mLastY);
//用戶滑動(dòng)超過(guò)3像素才會(huì)改變,這個(gè)可以不做,做只是為了避免很頻繁的相應(yīng)而已。
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);
//獲得當(dāng)前畫(huà)筆繪制文本的寬和高
mBackPaint.getTextBounds(mText, 0, mText.length(), mTextBound);
}
*//**
* 繪制path(也就是手刮動(dòng)的path來(lái)繪制) 的畫(huà)筆屬性
* 類似橡皮擦
*//*
private void setupOutPaint() {
mOutterPaint.setColor(Color.RED);
mOutterPaint.setAntiAlias(true);
mOutterPaint.setDither(true);
mOutterPaint.setStrokeJoin(Paint.Join.ROUND);//設(shè)置圓角
mOutterPaint.setStrokeCap(Paint.Cap.ROUND);
mOutterPaint.setStyle(Paint.Style.FILL);
mOutterPaint.setStrokeWidth(60);//設(shè)置畫(huà)筆寬度
}
*//**
* 初始化信息
*//*
private void init() {
mOutterPaint = new Paint();
mPath = new Path();
mOutterBitmap = BitmapFactory.decodeResource(getResources(),
R.drawable.huahua);
mText = "您中獎(jiǎng)了!";
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>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
詳解Android JetPack之LiveData的工作原理
這篇文章主要介紹了詳解Android JetPack之LiveData的工作原理,幫助大家更好的理解和學(xué)習(xí)使用Android開(kāi)發(fā),感興趣的朋友可以了解下2021-03-03
Android 8.0不能自動(dòng)安裝APK問(wèn)題的解決方法(完美適配)
這篇文章主要給大家介紹了關(guān)于Android 8.0不能自動(dòng)安裝APK問(wèn)題的解決方法(完美適配),這里的自動(dòng)安裝是指下載完成后,自動(dòng)彈出安裝界面,而不是靜默安裝APK,文中介紹的非常詳細(xì),需要的朋友可以參考下2018-07-07
Android getReadableDatabase() 和 getWritableDatabase()分析對(duì)比
這篇文章主要介紹了Android getReadableDatabase() 和 getWritableDatabase()分析對(duì)比的相關(guān)資料,需要的朋友可以參考下2017-06-06
Android實(shí)現(xiàn)ViewPager無(wú)限循環(huán)效果(一)
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)ViewPager無(wú)限循環(huán)效果的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05
Android實(shí)現(xiàn)掃一掃功能之繪制指定區(qū)域透明區(qū)域
這篇文章主要給大家介紹了關(guān)于Android實(shí)現(xiàn)掃一掃功能之繪制指定區(qū)域透明區(qū)域的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2018-07-07
Flutter?隊(duì)列任務(wù)的實(shí)現(xiàn)
本文主要介紹了Flutter?隊(duì)列任務(wù)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
Android+Html5混合開(kāi)發(fā)仿微信朋友圈
這篇文章主要為大家詳細(xì)介紹了Android+Html5混合開(kāi)發(fā)仿微信朋友圈的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11
Kotlin Channel處理多個(gè)數(shù)據(jù)組合的流
最近項(xiàng)目中對(duì) kotlin 的使用比較多。不得不說(shuō) kotlin 確實(shí)可以極大的提高 android 的開(kāi)發(fā)效率,channel用于協(xié)程之間的通訊,使用send和receive往通道里寫(xiě)入或者讀取數(shù)據(jù),2個(gè)方法為非阻塞掛起函數(shù),channel是熱流,不管有沒(méi)有訂閱者都會(huì)發(fā)送2022-11-11
android獲取圖片尺寸的兩種方式及bitmap的縮放操作
這篇文章主要介紹了android獲取圖片尺寸的兩種方式及bitmap的縮放操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-08-08
Android 百度地圖定位實(shí)現(xiàn)仿釘釘簽到打卡功能的完整代碼
這篇文章主要介紹了Android 百度地圖定位實(shí)現(xiàn)仿釘釘簽到打卡功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04

