国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

Android實現(xiàn)滑塊拼圖驗證碼功能

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

滑塊拼圖驗證碼應(yīng)該算是很常見的功能了,驗證碼是可以區(qū)分用戶是人還是機器。可以防止破解密碼、刷票等惡意行為。本文將介紹Android拼圖滑塊驗證碼控件的實現(xiàn)過程。希望能幫助到大家。

先看最終的效果圖:

Android實現(xiàn)滑塊拼圖驗證碼功能

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

一、實現(xiàn)步驟:

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

二、實現(xiàn)流程:

1、定義自定義屬性 創(chuàng)建一個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' /> <!--是否需要旋轉(zhuǎn)--> <attr name='needRotate' format='boolean' /> <!--驗證時的誤差值--> <attr name='deviate' format='integer' /> </declare-styleable>

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

/** * 創(chuàng)建目標圖片(陰影部分) */ 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); } // 如果需要旋轉(zhuǎn)圖片,進行旋轉(zhuǎn),旋轉(zhuǎn)后為了保持和滑塊大小一致,需要重新縮放比例 if (needRotate) { showB = handleBitmap(rotateBitmap(rotate, showB), mUintWidth, mUintHeight); } return showB; }

3、創(chuàng)建與目標位置相結(jié)合的滑塊圖片

/** * 創(chuàng)建結(jié)滑塊圖片 * * @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); } // 如果需要旋轉(zhuǎn)圖片,進行旋轉(zhuǎn),旋轉(zhuǎn)后為了和畫布大小保持一致,避免出現(xiàn)圖像顯示不全,需要重新縮放比例 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、設(shè)置目標陰影圖片和滑塊圖片可以隨機旋轉(zhuǎn),并保持一致

/** * 旋轉(zhuǎn)圖片 * * @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、創(chuàng)建拖拽條,使滑塊隨著拖拽條的拖拽而移動

//滑塊監(jiān)聽 mSeekBar.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() { @Override public void onProgressChanged(SeekBar seekBar, int i, boolean b) {//設(shè)置滑塊移動距離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、自定義控件內(nèi)容太多這里就不放出來了,完整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() { //滑塊監(jiān)聽 mSeekBar.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() { @Override public void onProgressChanged(SeekBar seekBar, int i, boolean b) {//設(shè)置滑塊移動距離mDY.setUnitMoveDistance(mDY.getAverageDistance(seekBar.getMax()) * i); } @Override public void onStartTrackingTouch(SeekBar seekBar) { } @Override public void onStopTrackingTouch(SeekBar seekBar) {//驗證是否拼接成功mDY.testPuzzle(); } }); //控件監(jiān)聽 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.cgvv.com.cn/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>

源碼下載

到此這篇關(guān)于Android實現(xiàn)滑塊拼圖驗證碼功能的文章就介紹到這了,更多相關(guān)Android 滑塊拼圖驗證碼內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標簽: Android
相關(guān)文章:
主站蜘蛛池模板: 国产精品免费观看视频播放 | 亚洲人成网站观看在线播放 | 国产毛片精品 | 中文字幕一区二区三区亚洲精品 | 免费观看女人一摸全是水 | 成人免费观看永久24小时 | 人人99 | 日韩欧美成人乱码一在线 | www伊人 | 久久精品男人的天堂 | 国产一区二区三区不卡在线观看 | 欧美日韩永久久一区二区三区 | 国产日韩欧美久久久 | 一级毛片免费 | 亚洲精品第一第二区 | 久久国产亚洲观看 | 欧美一级特黄真人毛片 | 国产成人小视频在线观看 | 免费伦费一区二区三区四区 | 久久久亚洲精品蜜桃臀 | 日本特爽特黄特刺激大片 | 在线成人亚洲 | 日韩特黄特色大片免费视频 | 美女在线看永久免费网址 | 2020国产成人免费视频 | 欧美国产精品亚洲精品第一区 | 国产人成久久久精品 | 国产日韩欧美在线一二三四 | 国产精品免费一区二区三区 | 99九九视频| 免费播放欧美毛片欧美aaaaa | 91久久香蕉国产线看观看软件 | 日韩欧免费一区二区三区 | 亚洲第一激情 | 精品a视频| 亚洲综合久久久久久888 | 高清国产在线播放成人 | 日本欧美一区二区三区高清 | 国产极品喷水视频jk制服 | 国产在线日韩在线 | 成熟性xxxxx 成网站在线观看人免费 |