Android二維碼之建立

  因爲微信的推出二維碼走進了咱們的生活,而且愈來愈多的人們正在發揮着本身的想象力去使用它,來方便咱們的生活,我曾經據說過一個笑話,當咱們死後,墓碑上再也不有墓誌銘,而會出現一個記錄你一輩子信息的二維碼,當人們走到大家的墓碑前,掏出手機掃一掃就能夠看到你一輩子的豐功偉績。這是否是頗有意思,我都認這會在不久的未來成爲現實,哈哈,玩笑說完了,下面咱們來一塊兒學習一下如何在Android開發中讓二維碼爲咱們服務。android

  本篇我將會帶領朋友們實現一個記錄我的基本信息的二維碼設計思路,對於搞過算法的大牛們,這裏要讓大家失望了,對於二維碼生成的算法,本人才疏學淺尚且沒法爲你們分享,本篇事例的實現咱們將藉助core.jar實現,對於這個jar包的下載,我爲你們提供一個連接,方便你們學習使用:http://pan.baidu.com/s/1bnGZoF9web

  準備好咱們的jar包後,咱們開始今天的設計,第一步:建立工程,導入jar包算法

  在咱們的集成開發環境中,建立一個Android工程項目,爲咱們今天事例的設計作鋪墊。建立好工程後,將咱們剛剛下載好的jar包導入到咱們的工程中,Ctrl+c咱們的jar包,在咱們的工程目錄下找到libs文件夾Ctrl+v,而後呢?就是經過集成開發環境將咱們的jar包導入到工程。數組

  

  第二步:建立咱們的佈局文件:微信

<RelativeLayout 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: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=".MainActivity" >
  <LinearLayout
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:orientation="vertical"
            android:id="@+id/ll"
            >
     <!-- 用於展現咱們建立的二維碼 -->
    <ImageView
        android:id="@+id/imgCode"
        android:layout_width="100dip"
        android:layout_height="100dip"
        android:layout_gravity="center_horizontal" />
           
            <!-- 公司 -->

            <LinearLayout
                android:layout_width="fill_parent"
                android:layout_height="wrap_content"
                android:orientation="horizontal" >

                <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="公司" />

                <EditText
                    android:id="@+id/etCompany"
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:hint="選填" />
            </LinearLayout>

         
            <!-- 電話 -->

            <LinearLayout
                android:layout_width="fill_parent"
                android:layout_height="wrap_content"
                android:orientation="horizontal" >

                <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="電話" />

                <EditText
                    android:id="@+id/etPhone"
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:hint="選填" />
            </LinearLayout>
            <!-- 郵箱 -->

            <LinearLayout
                android:layout_width="fill_parent"
                android:layout_height="wrap_content"
                android:orientation="horizontal" >

                <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="郵箱" />

                <EditText
                    android:id="@+id/etEmail"
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:hint="選填" />
            </LinearLayout>

            <!-- 網址 -->

            <LinearLayout
                android:layout_width="fill_parent"
                android:layout_height="wrap_content"
                android:orientation="horizontal" >

                <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="網址" />

                <EditText
                    android:id="@+id/etWeb"
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:text="http://" />
            </LinearLayout>

          
           
            <Button  android:id="@+id/but" 
                android:layout_width="fill_parent" 
                android:layout_height="wrap_content" 
                android:text="生成二維碼"/>
        </LinearLayout>

</RelativeLayout>

  第三步:編輯咱們Activity:ide

public class MainActivity extends Activity {

    private EditText etCompany;
    private EditText etPhone;
    private EditText etEmail;
    private EditText etWeb;

    
    private Bitmap logo;
    private static final int IMAGE_HALFWIDTH = 40;//寬度值,影響中間圖片大小
    
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //得到資源圖片,可改爲獲取本地圖片或拍照獲取圖片
        logo=BitmapFactory.decodeResource(super.getResources(), R.drawable.ic_launcher);
  
        etCompany =(EditText) findViewById(R.id.etCompany);
        etPhone=(EditText) findViewById(R.id.etPhone);
        etEmail =(EditText) findViewById(R.id.etEmail);
        etWeb =(EditText) findViewById(R.id.etWeb); 
        findViewById(R.id.but).setOnClickListener(new OnClickListener() {
            @Override
            public void onClick(View v) {
                String company=etCompany.getText().toString().trim() ;
                String phone =etPhone .getText().toString().trim() ; 
                String email = etEmail.getText().toString().trim() ;
                String web = etWeb.getText().toString().trim() ; 
                //二維碼中包含的文本信息
                String contents= "BEGIN:VCARD\nVERSION:3.0\nORG:"+company+"\nTEL:"+phone+"\nURL:"+web+"\nEMAIL:"+email+"\nEND:VCARD";
            try {
                //調用方法createCode生成二維碼
                Bitmap bm=createCode(contents, logo, BarcodeFormat.QR_CODE);
                ImageView img=(ImageView)findViewById(R.id.imgCode) ;
                //將二維碼在界面中顯示
                img.setImageBitmap(bm);
            } catch (WriterException e) {
                e.printStackTrace();
            } 
                
            }
        });
        
    }

    /**
     * 生成二維碼
     * @param string 二維碼中包含的文本信息
     * @param mBitmap logo圖片
     * @param format  編碼格式
     * @return Bitmap 位圖
     * @throws WriterException
     */
    public Bitmap createCode(String string,Bitmap mBitmap, BarcodeFormat format)
            throws WriterException {
        Matrix m = new Matrix();
        float sx = (float) 2 * IMAGE_HALFWIDTH / mBitmap.getWidth();
        float sy = (float) 2 * IMAGE_HALFWIDTH
                / mBitmap.getHeight();
        m.setScale(sx, sy);//設置縮放信息
        //將logo圖片按martix設置的信息縮放
        mBitmap = Bitmap.createBitmap(mBitmap, 0, 0,
                mBitmap.getWidth(), mBitmap.getHeight(), m, false);
        
        MultiFormatWriter writer = new MultiFormatWriter();//
        Hashtable<EncodeHintType, String> hst = new Hashtable<EncodeHintType, String>();
        hst.put(EncodeHintType.CHARACTER_SET, "UTF-8");//設置字符編碼
        BitMatrix matrix = writer.encode(string, format, 400, 400, hst);//生成二維碼矩陣信息
        int width = matrix.getWidth();//矩陣高度
        int height = matrix.getHeight();//矩陣寬度
        int halfW = width / 2;
        int halfH = height / 2;
        int[] pixels = new int[width * height];//定義數組長度爲矩陣高度*矩陣寬度,用於記錄矩陣中像素信息
        for (int y = 0; y < height; y++) {//從行開始迭代矩陣
            for (int x = 0; x < width; x++) {//迭代列
                if (x > halfW - IMAGE_HALFWIDTH && x < halfW + IMAGE_HALFWIDTH
                        && y > halfH - IMAGE_HALFWIDTH
                        && y < halfH + IMAGE_HALFWIDTH) {//次處位置用於存放圖片信息
                    pixels[y * width + x] = mBitmap.getPixel(x - halfW
                            + IMAGE_HALFWIDTH, y - halfH + IMAGE_HALFWIDTH);//記錄圖片每一個像素信息
                } else {
                    if (matrix.get(x, y)) {//若是有黑塊點,記錄信息
                        pixels[y * width + x] = 0xff000000;//記錄黑塊信息
                    }
                }

            }
        }
        Bitmap bitmap = Bitmap.createBitmap(width, height,
                Bitmap.Config.ARGB_8888);
        // 經過像素數組生成bitmap
        bitmap.setPixels(pixels, 0, width, 0, 0, width, height);
        return bitmap;
    }
    
}

  上面的代碼註釋已經很是詳細,這裏我再簡單說幾句,這部分代碼分爲上下兩部分,上部分都是咱們常常使用的,下部分則是咱們二維碼建立的重點。ok到這裏咱們的效果就實現了,最後上一張效果圖:佈局

  

相關文章
相關標籤/搜索