Android如何實(shí)現(xiàn)掃描和生成二維碼
本文實(shí)例為大家分享了Android實(shí)現(xiàn)掃描和生成二維碼的具體代碼,供大家參考,具體內(nèi)容如下
目標(biāo)效果:
該例子可以掃描二維碼和條形碼,掃描后會(huì)將信息顯示到下方的TextView中,在EditText中輸入想要生成的文本,點(diǎn)擊生成二維碼,會(huì)在下方顯示二維碼圖片。
1.二維碼的掃描與生成需要一個(gè)框架,網(wǎng)上的框架導(dǎo)入后改成is Library會(huì)提示錯(cuò)誤,把switch改成if語(yǔ)句錯(cuò)誤就沒(méi)有了。
2.導(dǎo)入框架并新建項(xiàng)目,把框架添加到項(xiàng)目中去。
3.activity_main.xml頁(yè)面設(shè)置控件。
activity_main.xml頁(yè)面:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" tools:context=".MainActivity" > <Button android:id="@+id/btScan" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="開始掃描二維碼" /> <TextView android:id="@+id/tvShow" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="20dp" android:text="二維碼結(jié)果:" /> <EditText android:id="@+id/etInput" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_marginTop="50dp" android:hint="請(qǐng)輸入要編碼的內(nèi)容"> </EditText> <Button android:id="@+id/btGet" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="生成二維碼" /> <ImageView android:id="@+id/ivCode" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal"/> </LinearLayout>
4.MainActivity.java頁(yè)面編寫點(diǎn)擊事件,進(jìn)行掃描生成二維碼。
MainActivity.java頁(yè)面:
package com.example.testqrcode; import com.google.zxing.WriterException; import com.zxing.activity.CaptureActivity; import com.zxing.encoding.EncodingHandler; import android.os.Bundle; import android.app.Activity; import android.content.Intent; import android.graphics.Bitmap; import android.view.Menu; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.EditText; import android.widget.ImageView; import android.widget.TextView; import android.widget.Toast; public class MainActivity extends Activity { private Button btScan, btGet; private TextView tvShow; private ImageView ivCode; private EditText etInput; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); btScan = (Button) findViewById(R.id.btScan); tvShow = (TextView) findViewById(R.id.tvShow); btGet = (Button) findViewById(R.id.btGet); ivCode = (ImageView) findViewById(R.id.ivCode); etInput = (EditText) findViewById(R.id.etInput); // 掃描二維碼 btScan.setOnClickListener(new OnClickListener() { @Override public void onClick(View arg0) { Toast.makeText(MainActivity.this, "你可以掃描條形碼或者二維碼", Toast.LENGTH_SHORT).show(); Intent intent = new Intent(MainActivity.this, CaptureActivity.class); // startActivity(intent); //不能回傳數(shù)據(jù)的跳轉(zhuǎn)方式 startActivityForResult(intent, 0); // 能獲取回傳數(shù)據(jù)的跳轉(zhuǎn)方式 } }); // 生成二維碼 btGet.setOnClickListener(new OnClickListener() { @Override public void onClick(View arg0) { String in = etInput.getText().toString(); if (in.equals("")) { Toast.makeText(MainActivity.this, "請(qǐng)輸入文本", Toast.LENGTH_SHORT).show(); } else { try { Bitmap qrcode = EncodingHandler.createQRCode(in, 400); ivCode.setImageBitmap(qrcode); } catch (WriterException e) { // TODO Auto-generated catch block e.printStackTrace(); }// 第一個(gè)參數(shù)是想要生成的文本,第二個(gè)參數(shù)是生成二維碼橫向和縱向的寬度 } } }); } // 接收掃描的activity傳回來(lái)的值 @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { super.onActivityResult(requestCode, resultCode, data); if (resultCode == RESULT_OK) { String result = data.getExtras().getString("result"); tvShow.setText(result); } } }
5.AndroidManifest.xml頁(yè)面添加權(quán)限。
<uses-permission android:name="android.permission.CAMERA"/> <uses-permission android:name="android.permission.VIBRATE"/>
6.AndroidManifest.xml頁(yè)面添加聲明掃描二維碼頁(yè)面的activity信息。
<activity android:name="com.zxing.activity.CaptureActivity" android:configChanges="orientation|keyboardHidden" android:screenOrientation="portrait" android:theme="@android:style/Theme.NoTitleBar.Fullscreen" android:windowSoftInputMode="stateAlwaysHidden" > </activity>
7.運(yùn)行就顯示目標(biāo)效果了。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android自定義view實(shí)現(xiàn)圓形waveview
這篇文章主要為大家詳細(xì)介紹了Android自定義view實(shí)現(xiàn)圓形waveview,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01Android 實(shí)例開發(fā)基于ArcSoft實(shí)現(xiàn)人臉識(shí)別
人臉識(shí)別,是基于人的臉部特征信息進(jìn)行身份識(shí)別的一種生物識(shí)別技術(shù)。用攝像機(jī)或攝像頭采集含有人臉的圖像或視頻流,并自動(dòng)在圖像中檢測(cè)和跟蹤人臉,進(jìn)而對(duì)檢測(cè)到的人臉進(jìn)行識(shí)別的一系列相關(guān)技術(shù),通常也叫做人像識(shí)別、面部識(shí)別2021-11-11Flutter文本Text和輸入框TextField組件使用示例
這篇文章主要為大家介紹了Flutter文本Text和輸入文本框TextField組件使用示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08Android簡(jiǎn)單實(shí)現(xiàn)彈幕效果
這篇文章主要為大家詳細(xì)介紹了Android簡(jiǎn)單實(shí)現(xiàn)彈幕效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-11-11Android中EditText+Button組合導(dǎo)致輸入板無(wú)法收起的原因分析及解決辦法
這篇文章主要介紹了Android中EditText+Button組合導(dǎo)致輸入板無(wú)法收起的原因分析及解決辦法的相關(guān)資料,需要的朋友可以參考下2016-01-01