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-03Android 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-07Android getReadableDatabase() 和 getWritableDatabase()分析對(duì)比
這篇文章主要介紹了Android getReadableDatabase() 和 getWritableDatabase()分析對(duì)比的相關(guān)資料,需要的朋友可以參考下2017-06-06Android實(shí)現(xiàn)ViewPager無(wú)限循環(huán)效果(一)
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)ViewPager無(wú)限循環(huán)效果的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05Android實(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-07Flutter?隊(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-06Android+Html5混合開(kāi)發(fā)仿微信朋友圈
這篇文章主要為大家詳細(xì)介紹了Android+Html5混合開(kāi)發(fā)仿微信朋友圈的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11Kotlin 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-11android獲取圖片尺寸的兩種方式及bitmap的縮放操作
這篇文章主要介紹了android獲取圖片尺寸的兩種方式及bitmap的縮放操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-08-08Android 百度地圖定位實(shí)現(xiàn)仿釘釘簽到打卡功能的完整代碼
這篇文章主要介紹了Android 百度地圖定位實(shí)現(xiàn)仿釘釘簽到打卡功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04