日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Android實現滑塊拼圖驗證碼功能

瀏覽:176日期:2022-09-20 17:28:08

滑塊拼圖驗證碼應該算是很常見的功能了,驗證碼是可以區分用戶是人還是機器??梢苑乐蛊平饷艽a、刷票等惡意行為。本文將介紹Android拼圖滑塊驗證碼控件的實現過程。希望能幫助到大家。

先看最終的效果圖:

Android實現滑塊拼圖驗證碼功能

本文只是做了個Demo,并沒有加入到實際的項目中,所以各位童鞋可以根據自己的需求就行修改即可。

一、實現步驟:

1、定義自定義屬性; 2、確認目標位置,這里使用的是陰影圖片來遮蓋背景圖片; 3、創建與目標位置相結合的滑塊圖片; 4、設置目標陰影圖片和滑塊圖片可以隨機旋轉,并保持一致; 5、創建拖拽條,使滑塊隨著拖拽條的拖拽而移動; 6、判斷是否驗證成功。

二、實現流程:

1、定義自定義屬性 創建一個attr文件來定義一些自定義屬性

<declare-styleable name='ImageAuthenticationView'> <!--滑塊的高度--> <attr name='unitHeight' format='dimension' /> <!--滑塊的寬度--> <attr name='unitWidth' format='dimension' /> <!--滑塊占圖片高度的比例--> <attr name='unitHeightScale' format='integer' /> <!--滑塊占圖片寬度的比例--> <attr name='unitWidthScale' format='integer' /> <!--滑塊邊框的圖片資源--> <attr name='unitShadeSrc' format='reference' /> <!--陰影部分的圖片資源--> <attr name='unitShowSrc' format='reference' /> <!--是否需要旋轉--> <attr name='needRotate' format='boolean' /> <!--驗證時的誤差值--> <attr name='deviate' format='integer' /> </declare-styleable>

2、確認目標位置,這里使用的是陰影圖片來遮蓋背景圖片

/** * 創建目標圖片(陰影部分) */ private Bitmap drawTargetBitmap() { // 繪制圖片 Bitmap showB; if (null != mShowBp) { showB = handleBitmap(mShowBp, mUintWidth, mUintHeight); } else { showB = handleBitmap(BitmapFactory.decodeResource(getResources(), R.mipmap.puzzle_show), mUintWidth, mUintHeight); } // 如果需要旋轉圖片,進行旋轉,旋轉后為了保持和滑塊大小一致,需要重新縮放比例 if (needRotate) { showB = handleBitmap(rotateBitmap(rotate, showB), mUintWidth, mUintHeight); } return showB; }

3、創建與目標位置相結合的滑塊圖片

/** * 創建結滑塊圖片 * * @param bp */ private Bitmap drawResultBitmap(Bitmap bp) { // 繪制圖片 Bitmap shadeB; if (null != mShadeBp) { shadeB = handleBitmap(mShadeBp, mUintWidth, mUintHeight); } else { shadeB = handleBitmap(BitmapFactory.decodeResource(getResources(), R.mipmap.puzzle_shade), mUintWidth, mUintHeight); } // 如果需要旋轉圖片,進行旋轉,旋轉后為了和畫布大小保持一致,避免出現圖像顯示不全,需要重新縮放比例 if (needRotate) { shadeB = handleBitmap(rotateBitmap(rotate, shadeB), mUintWidth, mUintHeight); } Bitmap resultBmp = Bitmap.createBitmap(mUintWidth, mUintHeight,Bitmap.Config.ARGB_8888); Paint paint = new Paint(); paint.setAntiAlias(true); Canvas canvas = new Canvas(resultBmp); canvas.drawBitmap(shadeB, new Rect(0, 0, mUintWidth, mUintHeight),new Rect(0, 0, mUintWidth, mUintHeight), paint); // 選擇交集去上層圖片 paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.MULTIPLY)); canvas.drawBitmap(bp, new Rect(0, 0, mUintWidth, mUintHeight),new Rect(0, 0, mUintWidth, mUintHeight), paint); return resultBmp; }

4、設置目標陰影圖片和滑塊圖片可以隨機旋轉,并保持一致

/** * 旋轉圖片 * * @param degree * @param bitmap * @return */ public Bitmap rotateBitmap(int degree, Bitmap bitmap) { Matrix matrix = new Matrix(); matrix.postRotate(degree); Bitmap bm = Bitmap.createBitmap(bitmap, 0, 0, bitmap.getWidth(),bitmap.getHeight(), matrix, true); return bm; }

5、創建拖拽條,使滑塊隨著拖拽條的拖拽而移動

//滑塊監聽 mSeekBar.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() { @Override public void onProgressChanged(SeekBar seekBar, int i, boolean b) {//設置滑塊移動距離mDY.setUnitMoveDistance(mDY.getAverageDistance(seekBar.getMax()) * i); } @Override public void onStartTrackingTouch(SeekBar seekBar) { } @Override public void onStopTrackingTouch(SeekBar seekBar) {//驗證是否拼接成功mDY.testPuzzle(); } });

6、判斷是否驗證成功

/** * 驗證是否拼接成功 */ public void testPuzzle() { if (Math.abs(mUnitMoveDistance - mUnitRandomX) <= DEFAULT_DEVIATE) { if (null != mlistener) {mlistener.onSuccess(); } } else { if (null != mlistener) {mlistener.onFail(); } } }三、完整代碼

1、自定義控件內容太多這里就不放出來了,完整Demo源碼會放在文章后面;

2、代碼邏輯

public class MainActivity extends Activity { //滑塊 private SeekBar mSeekBar; //自定義的控件 private ImageAuthenticationView mDY; private Button btn; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initView(); initListener(); } private void initView() { mDY = findViewById(R.id.dy_v); mSeekBar = findViewById(R.id.sb_dy); btn = findViewById(R.id.btn); } private void initListener() { //滑塊監聽 mSeekBar.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() { @Override public void onProgressChanged(SeekBar seekBar, int i, boolean b) {//設置滑塊移動距離mDY.setUnitMoveDistance(mDY.getAverageDistance(seekBar.getMax()) * i); } @Override public void onStartTrackingTouch(SeekBar seekBar) { } @Override public void onStopTrackingTouch(SeekBar seekBar) {//驗證是否拼接成功mDY.testPuzzle(); } }); //控件監聽 mDY.setPuzzleListener(new ImageAuthenticationView.onPuzzleListener() { @Override public void onSuccess() {//mSeekBar.setEnabled(false);//禁止滑動Toast.makeText(MainActivity.this, '驗證成功', Toast.LENGTH_SHORT).show(); } @Override public void onFail() {Toast.makeText(MainActivity.this, '驗證失敗', Toast.LENGTH_SHORT).show();mSeekBar.setProgress(0); } }); //重置 btn.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) {//mSeekBar.setEnabled(true);mSeekBar.setProgress(0);mDY.reSet(); } }); }}

3、布局文件

<?xml version='1.0' encoding='utf-8'?><LinearLayout xmlns:android='http://schemas.android.com/apk/res/android' xmlns:dy='http://schemas.android.com/apk/res-auto' xmlns:tools='http://schemas.android.com/tools' android:layout_width='match_parent' android:layout_height='match_parent' android:gravity='center' android:orientation='vertical' android:paddingLeft='10dp' android:paddingTop='10dp' android:paddingRight='10dp' android:paddingBottom='10dp' tools:context='.MainActivity'> <com.sjl.keeplive.slideImg.ImageAuthenticationView android: android:layout_width='match_parent' android:layout_height='wrap_content' android:scaleType='centerCrop' android:layout_marginBottom='10dp' android:src='http://m.b3g6.com/bcjs/@mipmap/test' dy:needRotate='true' dy:unitHeight='60dp' dy:unitShadeSrc='@mipmap/puzzle_shade' dy:unitShowSrc='@mipmap/puzzle_show' dy:unitWidth='80dp' /> <SeekBar android: android:layout_width='match_parent' android:layout_height='wrap_content' android:background='@drawable/bg_seekbar' android:max='100' /> <Button android: android:layout_width='wrap_content' android:layout_height='wrap_content' android:text='重置'/></LinearLayout>

源碼下載

到此這篇關于Android實現滑塊拼圖驗證碼功能的文章就介紹到這了,更多相關Android 滑塊拼圖驗證碼內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Android
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
成人日韩av| 亚洲一区免费| 国产精品s色| 国产在线一区不卡| 久久精品青草| 玖玖玖国产精品| 91精品啪在线观看国产爱臀| 精品一区二区三区中文字幕在线| 日韩免费高清| 亚洲一区二区三区四区五区午夜 | 欧美视频精品全部免费观看| 亚洲影院天堂中文av色| 日韩亚洲精品在线观看| 国产亚洲亚洲| 国产精品红桃| 久久精品国产亚洲夜色av网站| 国产精品普通话对白| 国产精品久久久久av蜜臀| 视频福利一区| 欧美va天堂在线| 蜜臀av性久久久久蜜臀aⅴ四虎 | 日韩在线卡一卡二| 欧美亚洲专区| 欧洲av一区二区| 日韩不卡手机在线v区| 欧美xxxx中国| 正在播放日韩精品| 午夜久久福利| 日韩一区二区三区在线看| 欧美丰满日韩| 久久久久国产一区二区| 亚洲精品第一| 亚洲国产福利| 亚洲欧美日韩国产一区二区| 免费看一区二区三区| 亚洲视频播放| sm久久捆绑调教精品一区| 国产精品老牛| 美女久久精品| 日韩欧美一区二区三区在线观看| 婷婷成人基地| 国产精品国码视频| 美日韩精品视频| 欧美成人a交片免费看| 日本aⅴ亚洲精品中文乱码| 免费黄色成人| 国产一区二区三区四区大秀| 蜜臀a∨国产成人精品| 欧美国产先锋| 视频一区日韩| 伊人成人网在线看| 精品黄色一级片| 四虎国产精品免费久久| 亚洲精品小说| 正在播放日韩精品| 国产欧美一区二区精品久久久| 免费欧美一区| 欧美少妇精品| 91精品国产经典在线观看 | 亚洲精品九九| 91九色精品国产一区二区| a天堂资源在线| 国产精品久久久久久模特| 亚洲精品影视| 1024精品久久久久久久久| 四虎国产精品免费观看| 国产精品成人国产| 88久久精品| 亚洲欧洲日韩精品在线| 国产精品88久久久久久| 国产aⅴ精品一区二区四区| 青草av.久久免费一区| 西西人体一区二区| 亚洲天堂久久| 久久一区二区三区喷水| 国内精品伊人| 你懂的网址国产 欧美| 亚洲精品成人一区| 亚洲精品人人| 亚洲区国产区| 亚洲精品乱码| 日韩高清中文字幕一区| 亚洲综合中文| 亚洲开心激情| 亚洲精品日本| 日本欧美在线| 日本午夜精品久久久久| 日韩激情综合| 国产精一区二区| 国产欧美日韩在线观看视频| 国产精品天堂蜜av在线播放| 久久国际精品| 国产劲爆久久| 九九在线精品| 婷婷成人基地| 免费观看日韩电影| 日本中文字幕不卡| 国产亚洲一区二区三区啪| 久久精品99国产精品| 国产女人18毛片水真多18精品| 国产精品亚洲综合色区韩国| 久久99国产精品视频| 日韩欧美三级| 香蕉人人精品| 美女久久一区| 国产精品日韩精品在线播放 | 成人av三级| 91精品成人| 中文字幕一区二区三区日韩精品| 日韩福利视频一区| 国产精品一国产精品| 国产精品99一区二区三| 久久九九国产| 蜜臀久久久99精品久久久久久| 日韩国产欧美在线播放| 久久99久久久精品欧美| 日本激情一区| 亚洲性图久久| 国产一区观看| 精品日韩毛片| 日本成人中文字幕| 亚洲欧洲日韩| 九九九精品视频| 久久精品主播| 日日夜夜免费精品| 久久久久九九精品影院| 日韩精品看片| 在线日韩成人| 久久三级毛片| 91精品二区| 国产精品毛片久久久| 久久中文字幕av| 婷婷亚洲成人| 精品一区二区三区免费看| 久久精品不卡| 日本久久一区| 久久国产影院| 日韩精品成人在线观看| 综合日韩av| 免费人成网站在线观看欧美高清| 国产日韩欧美在线播放不卡| 亚洲精品88| 丝瓜av网站精品一区二区| 麻豆国产一区| 亚洲激情av| 美女毛片一区二区三区四区最新中文字幕亚洲 | 丝袜美腿亚洲一区二区图片| 国产精品一区二区免费福利视频| 欧美日韩一二三四| 日韩精品一区第一页| 欧美91在线| 蜜臀久久久久久久| 日韩激情一区| 亚洲区国产区| 久久国产中文字幕| 欧美黑人做爰爽爽爽| 亚洲自啪免费| 精品日产乱码久久久久久仙踪林| 国产视频一区在线观看一区免费| 国产福利资源一区| 红桃视频国产精品| 久久香蕉精品香蕉| 亚洲欧洲日韩| 女人天堂亚洲aⅴ在线观看| 久久这里只有精品一区二区| 在线精品福利| 99久久九九| 开心激情综合| 日韩精选在线| 国产亚洲精品久久久久婷婷瑜伽| 精品国产aⅴ| 日本成人在线视频网站| 不卡在线一区| 欧洲精品一区二区三区| 国产精品亚洲欧美日韩一区在线 | 五月天综合网站| 国产精品毛片一区二区在线看| 香蕉久久一区| 99re国产精品| 亚洲性色av| 狂野欧美性猛交xxxx| 91嫩草精品| 一本一道久久a久久| 午夜视频精品| 久久91导航| 日本一二区不卡| 国产精品地址| 国产人成精品一区二区三| 亚洲欧美日韩国产综合精品二区 | 久久久一二三| 欧美www视频在线观看| 国产精东传媒成人av电影| 亚洲免费福利一区| 免费精品视频| 91久久视频| 亚洲成人精品| 精品免费av一区二区三区| 国产调教精品| 91精品丝袜国产高跟在线| 四虎成人精品一区二区免费网站|