1、导入zxing代码和包

2、下面的类是解析二维码的主要类。

  1. package com.gaint.nebula.interaction.ui.zxing;
  2.  
  3. import java.io.IOException;
  4. import java.util.Vector;
  5.  
  6. import android.app.Activity;
  7. import android.content.Intent;
  8. import android.content.res.AssetFileDescriptor;
  9. import android.graphics.Bitmap;
  10. import android.media.AudioManager;
  11. import android.media.MediaPlayer;
  12. import android.media.MediaPlayer.OnCompletionListener;
  13. import android.os.Bundle;
  14. import android.os.Handler;
  15. import android.os.Vibrator;
  16. import android.view.SurfaceHolder;
  17. import android.view.SurfaceHolder.Callback;
  18. import android.view.SurfaceView;
  19. import android.view.View;
  20. import android.view.View.OnClickListener;
  21. import android.widget.Button;
  22. import android.widget.Toast;
  23.  
  24. import com.gaint.nebula.interaction.R;
  25. import com.gaint.nebula.interaction.ui.BaseActivity;
  26. import com.google.zxing.BarcodeFormat;
  27. import com.google.zxing.Result;
  28. import com.mining.app.zxing.camera.CameraManager;
  29. import com.mining.app.zxing.decoding.CaptureActivityHandler;
  30. import com.mining.app.zxing.decoding.InactivityTimer;
  31. import com.mining.app.zxing.view.ViewfinderView;
  32. /**
  33. * Initial the camera
  34. * @author Ryan.Tang
  35. */
  36. public class MipcaActivityCapture extends BaseActivity implements Callback {
  37.  
  38. private CaptureActivityHandler handler;
  39. private ViewfinderView viewfinderView;
  40. private boolean hasSurface;
  41. private Vector<BarcodeFormat> decodeFormats;
  42. private String characterSet;
  43. private InactivityTimer inactivityTimer;
  44. private MediaPlayer mediaPlayer;
  45. private boolean playBeep;
  46. private static final float BEEP_VOLUME = 0.10f;
  47. private boolean vibrate;
  48.  
  49. /** Called when the activity is first created. */
  50. @Override
  51. public void onCreate(Bundle savedInstanceState) {
  52. super.onCreate(savedInstanceState);
  53. setContentView(R.layout.activity_capture);
  54. //ViewUtil.addTopView(getApplicationContext(), this, R.string.scan_card);
  55. CameraManager.init(getApplication());
  56. viewfinderView = (ViewfinderView) findViewById(R.id.viewfinder_view);
  57.  
  58. Button mButtonBack = (Button) findViewById(R.id.button_back);
  59. mButtonBack.setOnClickListener(new OnClickListener() {
  60.  
  61. @Override
  62. public void onClick(View v) {
  63. MipcaActivityCapture.this.finish();
  64.  
  65. }
  66. });
  67. hasSurface = false;
  68. inactivityTimer = new InactivityTimer(this);
  69. }
  70.  
  71. @Override
  72. protected void onResume() {
  73. super.onResume();
  74. SurfaceView surfaceView = (SurfaceView) findViewById(R.id.preview_view);
  75. SurfaceHolder surfaceHolder = surfaceView.getHolder();
  76. if (hasSurface) {
  77. initCamera(surfaceHolder);
  78. } else {
  79. surfaceHolder.addCallback(this);
  80. surfaceHolder.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS);
  81. }
  82. decodeFormats = null;
  83. characterSet = null;
  84.  
  85. playBeep = true;
  86. AudioManager audioService = (AudioManager) getSystemService(AUDIO_SERVICE);
  87. if (audioService.getRingerMode() != AudioManager.RINGER_MODE_NORMAL) {
  88. playBeep = false;
  89. }
  90. initBeepSound();
  91. vibrate = true;
  92.  
  93. }
  94.  
  95. @Override
  96. protected void onPause() {
  97. super.onPause();
  98. if (handler != null) {
  99. handler.quitSynchronously();
  100. handler = null;
  101. }
  102. CameraManager.get().closeDriver();
  103. }
  104.  
  105. @Override
  106. protected void onDestroy() {
  107. inactivityTimer.shutdown();
  108. super.onDestroy();
  109. }
  110.  
  111. /**
  112. * ����ɨ����
  113. * @param result
  114. * @param barcode
  115. */
  116. public void handleDecode(Result result, Bitmap barcode) {
  117. inactivityTimer.onActivity();
  118. playBeepSoundAndVibrate();
  119. String resultString = result.getText();
  120. if (resultString.equals("")) {
  121. Toast.makeText(MipcaActivityCapture.this, "Scan failed!", Toast.LENGTH_SHORT).show();
  122. }else {
  123. Intent resultIntent = new Intent();
  124. Bundle bundle = new Bundle();
  125. bundle.putString("result", resultString);
  126. bundle.putParcelable("bitmap", barcode);
  127. resultIntent.putExtras(bundle);
  128. this.setResult(RESULT_OK, resultIntent);
  129. }
  130. MipcaActivityCapture.this.finish();
  131. }
  132.  
  133. private void initCamera(SurfaceHolder surfaceHolder) {
  134. try {
  135. CameraManager.get().openDriver(surfaceHolder);
  136. } catch (IOException ioe) {
  137. return;
  138. } catch (RuntimeException e) {
  139. return;
  140. }
  141. if (handler == null) {
  142. handler = new CaptureActivityHandler(this, decodeFormats,
  143. characterSet);
  144. }
  145. }
  146.  
  147. @Override
  148. public void surfaceChanged(SurfaceHolder holder, int format, int width,
  149. int height) {
  150.  
  151. }
  152.  
  153. @Override
  154. public void surfaceCreated(SurfaceHolder holder) {
  155. if (!hasSurface) {
  156. hasSurface = true;
  157. initCamera(holder);
  158. }
  159.  
  160. }
  161.  
  162. @Override
  163. public void surfaceDestroyed(SurfaceHolder holder) {
  164. hasSurface = false;
  165.  
  166. }
  167.  
  168. public ViewfinderView getViewfinderView() {
  169. return viewfinderView;
  170. }
  171.  
  172. public Handler getHandler() {
  173. return handler;
  174. }
  175.  
  176. public void drawViewfinder() {
  177. viewfinderView.drawViewfinder();
  178.  
  179. }
  180.  
  181. private void initBeepSound() {
  182. if (playBeep && mediaPlayer == null) {
  183. // The volume on STREAM_SYSTEM is not adjustable, and users found it
  184. // too loud,
  185. // so we now play on the music stream.
  186. setVolumeControlStream(AudioManager.STREAM_MUSIC);
  187. mediaPlayer = new MediaPlayer();
  188. mediaPlayer.setAudioStreamType(AudioManager.STREAM_MUSIC);
  189. mediaPlayer.setOnCompletionListener(beepListener);
  190.  
  191. AssetFileDescriptor file = getResources().openRawResourceFd(
  192. R.raw.beep);
  193. try {
  194. mediaPlayer.setDataSource(file.getFileDescriptor(),
  195. file.getStartOffset(), file.getLength());
  196. file.close();
  197. mediaPlayer.setVolume(BEEP_VOLUME, BEEP_VOLUME);
  198. mediaPlayer.prepare();
  199. } catch (IOException e) {
  200. mediaPlayer = null;
  201. }
  202. }
  203. }
  204.  
  205. private static final long VIBRATE_DURATION = 200L;
  206.  
  207. private void playBeepSoundAndVibrate() {
  208. if (playBeep && mediaPlayer != null) {
  209. mediaPlayer.start();
  210. }
  211. if (vibrate) {
  212. Vibrator vibrator = (Vibrator) getSystemService(VIBRATOR_SERVICE);
  213. vibrator.vibrate(VIBRATE_DURATION);
  214. }
  215. }
  216.  
  217. /**
  218. * When the beep has finished playing, rewind to queue up another one.
  219. */
  220. private final OnCompletionListener beepListener = new OnCompletionListener() {
  221. public void onCompletion(MediaPlayer mediaPlayer) {
  222. mediaPlayer.seekTo(0);
  223. }
  224. };
  225.  
  226. }

3、调用此类:

  1. Intent intent = new Intent();
  2. intent.setClass(BaseActivity.this, MipcaActivityCapture.class);
  3. intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
  4. startActivityForResult(intent, SCANNIN_GREQUEST_CODE);

4、回传信息,可以看到二维码图片和内容。

  1. @Override
  2. protected void onActivityResult(int requestCode, int resultCode, Intent data) {
  3. if (requestCode == SCANNIN_GREQUEST_CODE) {
  4. if (data==null) {
  5. return;
  6. }
  7. Bitmap mBitmap = data.getParcelableExtra("bitmap");
  8. final String result = data.getStringExtra("result");
  9. Logger.getLogger().i(result+" -- "+mBitmap);
  10. View view = LayoutInflater.from(this).inflate(R.layout.scan, null);
  11. ImageView icon = (ImageView) view.findViewById(R.id.iv_scan_icon);
  12. TextView textView = (TextView) view.findViewById(R.id.tv_scan_title);
  13. icon.setImageBitmap(mBitmap);
  14. textView.setText(result);
  15. AlertDialog.Builder dialog = new AlertDialog.Builder(this);
  16. dialog.setTitle("扫描结果");
  17. dialog.setView(view);
  18. dialog.setMessage(data.getDataString());
  19. dialog.setNegativeButton("确定", new DialogInterface.OnClickListener() {
  20. @Override
  21. public void onClick(DialogInterface dialog, int which) {
  22. // 用默认浏览器打开扫描得到的地址
  23. Intent intent = new Intent();
  24. intent.setAction("android.intent.action.VIEW");
  25. Uri content_url = Uri.parse(result);
  26. intent.setData(content_url);
  27. startActivity(intent);
  28. dialog.dismiss();
  29. }
  30. });
  31. dialog.setPositiveButton("取消", new DialogInterface.OnClickListener() {
  32. @Override
  33. public void onClick(DialogInterface dialog, int which) {
  34. dialog.dismiss();
  35. }
  36. });
  37. dialog.create().show();
  38. }
  39. super.onActivityResult(requestCode, resultCode, data);
  40. }

5、生成二维码

  1. /**
  2. * @类功能说明: 生成二维码图片示例
  3. */
  4. public class CreateQRImageTest {
  5. private ImageView sweepIV;
  6. private int QR_WIDTH = 200, QR_HEIGHT = 200;
  7.  
  8. /**
  9. * @方法功能说明: 生成二维码图片,实际使用时要初始化sweepIV,不然会报空指针错误
  10. * @参数: @param url 要转换的地址或字符串,可以是中文
  11. * @return void
  12. * @throws
  13. */
  14.  
  15. // 要转换的地址或字符串,可以是中文
  16. public void createQRImage(String url) {
  17. try {
  18. // 判断URL合法性
  19. if (url == null || "".equals(url) || url.length() < 1) {
  20. return;
  21. }
  22. Hashtable<EncodeHintType, String> hints = new Hashtable<EncodeHintType, String>();
  23. hints.put(EncodeHintType.CHARACTER_SET, "utf-8");
  24. // 图像数据转换,使用了矩阵转换
  25. BitMatrix bitMatrix = new QRCodeWriter().encode(url,
  26. BarcodeFormat.QR_CODE, QR_WIDTH, QR_HEIGHT, hints);
  27. int[] pixels = new int[QR_WIDTH * QR_HEIGHT];
  28. // 下面这里按照二维码的算法,逐个生成二维码的图片,
  29. // 两个for循环是图片横列扫描的结果
  30. for (int y = 0; y < QR_HEIGHT; y++) {
  31. for (int x = 0; x < QR_WIDTH; x++) {
  32. if (bitMatrix.get(x, y)) {
  33. pixels[y * QR_WIDTH + x] = 0xff000000;
  34. } else {
  35. pixels[y * QR_WIDTH + x] = 0xffffffff;
  36. }
  37. }
  38. }
  39. // 生成二维码图片的格式,使用ARGB_8888
  40. Bitmap bitmap = Bitmap.createBitmap(QR_WIDTH, QR_HEIGHT,
  41. Bitmap.Config.ARGB_8888);
  42. bitmap.setPixels(pixels, 0, QR_WIDTH, 0, 0, QR_WIDTH, QR_HEIGHT);
  43. // 显示到一个ImageView上面
  44. sweepIV.setImageBitmap(bitmap);
  45. } catch (WriterException e) {
  46. e.printStackTrace();
  47. }
  48. }
  49. }

6、zxing包

http://www.cnblogs.com/weixing/archive/2013/08/28/3287120.html

ZXing开源项目Google Code地址:https://code.google.com/p/zxing/

ZXingDemo下载:ZXingDemo2013-8-25.rar

二、修改二维码代码

1、是扫描二维码的文字居中。

找到类ViewfinderView,其中widthPixels是屏幕的宽度。

  1. paint.setColor(Color.WHITE);
  2. paint.setTextSize(TEXT_SIZE * density);
  3. paint.setAlpha(0x40);
  4. paint.setTypeface(Typeface.create("System", Typeface.BOLD));
  5. //获取文字宽度,让其居中显示
  6. float wtext = paint.measureText(getResources().getString(R.string.scan_text));
  7. canvas.drawText(getResources().getString(R.string.scan_text), (widthPixels-wtext)/2, (float) (frame.bottom + (float)TEXT_PADDING_TOP *density), paint);

2、修改二维码窗口大小。默认情况下,窗口的大小是屏幕的四分之三,有最小值和最大值。

找到CameraManager类的getFramingRect方法,就可以看到。

  1. public Rect getFramingRect() {
  2. Point screenResolution = configManager.getScreenResolution();
  3. if (framingRect == null) {
  4. if (camera == null) {
  5. return null;
  6. }
  7. int width = screenResolution.x * 3 / 4;
  8. if (width < MIN_FRAME_WIDTH) {
  9. width = MIN_FRAME_WIDTH;
  10. } else if (width > MAX_FRAME_WIDTH) {
  11. width = MAX_FRAME_WIDTH;
  12. }
  13. int height = screenResolution.y * 3 / 4;
  14. if (height < MIN_FRAME_HEIGHT) {
  15. height = MIN_FRAME_HEIGHT;
  16. } else if (height > MAX_FRAME_HEIGHT) {
  17. height = MAX_FRAME_HEIGHT;
  18. }
  19. int leftOffset = (screenResolution.x - width) / 2;
  20. int topOffset = (screenResolution.y - height) / 2;
  21. framingRect = new Rect(leftOffset, topOffset, leftOffset + width, topOffset + height);
  22. Log.d(TAG, "Calculated framing rect: " + framingRect);
  23. }
  24. return framingRect;
  25. }

最近没事做了下二维码扫描,用的是ZXing的开源代码,官方源码地址:http://code.google.com/p/zxing/downloads/list;

我是在ZXing2.2基础上做的,因此只下载了ZXing-2.2.zip;

此外还需要ZXing的核心Jar包,下载地址:http://repo1.maven.org/maven2/com/google/zxing/core/2.2/,只需下载core-2.2.jar就行;

将下载的ZXing-2.2.zip解压出来,我们只需要用到android目录中的示例项目,如图:

 

将android项目导入eclipse,同时别忘了将core-2.2.jar导入libs,此时该示例项目应该可以运行了,不过该项目很多功能我们不需要,并且其扫描界面为横向的,因此需对其修改。



接下去我们来将该示例项目简化:

第一步:拷贝必要的包和类

新建自己的项目并导入core-2.2.jar,将示例项目中的必要代码全部拷贝到自己的项目中,至于示例项目中各个包和类的功能此处就不做解释的,有兴趣可以自己去研究下;

我自己对包结构做了一点改动,导入完成后会有很多红叉,大都和包的访问权限有关,因为示例代码中很多类是final型的,我们将其public就行;

此外还需要res下一些关联的文件(values下的color.xml、ids.xml、strings.xml,raw下的beep.ogg)。

初步调整后包结构如下:

 



第二步:PreferencesActivity和CaptureActivity修改

示例项目用到了大量的配置,因此很多地方都用到了PreferencesActivity这个类,其实留着它也无所谓,但别忘了将示例项目中res下一些关联文件拷贝过来(preferences.xml、arrays.xml);

不过PreferencesActivity完全是多余的,看着也碍眼,因此我将其去掉,需要将用到PreferencesActivity的类都修改,就是剩余那些报红叉的类,我们需要将一些配置固定化,多余的设置判断去掉,此处我就不贴代码了;

同样CaptureActivity中也有很多方法是我们不需要的,大都是关于解码成功后的处理,如果要保留的话则需要额外拷贝很多类,因此将其去掉,此处也不贴代码了,附件源码中都有。



第三部:修改为竖屏

经过上面两步,我们自己的项目应该可以运行了(别忘了加权限),当然此时是横屏的,因此我们需要修改几处地方将其修改为竖屏:

1.CameraConfigurationManager类的initFromCameraParameters()方法中将以下代码注释掉:

代码片段,双击复制
01
02
03
04
05
06
if(width
< height) {
   Log.i(TAG,"Display
reports portrait orientation; assuming this is incorrect"
);
   inttemp
= width;
   width
= height;
     height
= temp;
   }

2.CameraConfigurationManager类的setDesiredCameraParameters()方法中在camera.setParameters(parameters)之前加入以下代码:

代码片段,双击复制
01
camera.setDisplayOrientation(90);

3.CameraManager类的getFramingRectInPreview()方法中将以下代码替换:

代码片段,双击复制
01
02
03
04
rect.left
= rect.left * cameraResolution.x / screenResolution.x;
rect.right
= rect.right * cameraResolution.x / screenResolution.x;
rect.top
= rect.top * cameraResolution.y / screenResolution.y;
rect.bottom
= rect.bottom * cameraResolution.y / screenResolution.y;

替换为

代码片段,双击复制
01
02
03
04
rect.left
= rect.left * cameraResolution.y / screenResolution.x;
rect.right
= rect.right * cameraResolution.y / screenResolution.x;
rect.top
= rect.top * cameraResolution.x / screenResolution.y;
rect.bottom
= rect.bottom * cameraResolution.x / screenResolution.y;

4.DecodeHandler类的decode方法中在activity.getCameraManager().buildLuminanceSource()之前添加以下代码:

代码片段,双击复制
01
02
03
04
05
06
07
08
09
byte[]
rotatedData =
newbyte[data.length];
for(inty
=
0;
y < height; y++) {
   for(intx
=
0;
x < width; x++)
    
   
rotatedData[x
* height + height - y -
1]
= data[x + y * width];
    
   
}
 inttmp
= width;
 width
= height;
 height
= tmp;
 data
= rotatedData;

5.很关键的一步,解决竖屏后图像拉伸问题。CameraConfigurationManager类的initFromCameraParameters()方法中:

在Log.i(TAG, "Screen resolution: " + screenResolution);之后添加以下代码:

代码片段,双击复制
01
02
03
04
05
06
07
Point
screenResolutionForCamera =
newPoint();
screenResolutionForCamera.x
= screenResolution.x;
screenResolutionForCamera.y
= screenResolution.y;
if(screenResolution.x
< screenResolution.y) {
   screenResolutionForCamera.x
= screenResolution.y;
   screenResolutionForCamera.y
= screenResolution.x;
   }

同时修改下一句为cameraResolution = findBestPreviewSizeValue(parameters,screenResolutionForCamera);



此外manifest中别忘了设置android:screenOrientation="portrait",至此竖屏修改完毕。



第四步:扫描框位置和大小修改

此时的扫描框是竖直拉伸的矩形,很难看,我们可以将其修改为正方形或扁平型的。

CameraManager类的getFramingRect()方法中替换以下代码:

代码片段,双击复制
01
02
intwidth
= findDesiredDimensionInRange(screenResolution.x, MIN_FRAME_WIDTH, MAX_FRAME_WIDTH);
intheight
= findDesiredDimensionInRange(screenResolution.y,MIN_FRAME_HEIGHT, MAX_FRAME_HEIGHT);

替换为

代码片段,双击复制
01
02
03
DisplayMetrics
metrics = context.getResources().getDisplayMetrics();
intwidth
= (
int)
(metrics.widthPixels *
0.6);
intheight
= (
int)
(width *
0.9);

此处我们根据屏幕分辨率来定扫描框大小更灵活一点,同时将偏移量topOffset修改为(screenResolution.y - height)/4



第五步:扫描框四个角和扫描线条修改

示例代码中的线条是居中且不动的,我们可以将其修改为上下移动的扫描线,且可以改变线条的样式。

在自定义扫描布局ViewfinderView类中的onDraw()方法中绘制四个角,关键代码如下:

代码片段,双击复制
01
02
03
04
05
06
07
08
09
10
11
12
13
14
//
画出四个角
paint.setColor(getResources().getColor(R.color.green));
//
左上角
canvas.drawRect(frame.left,
frame.top, frame.left +
15,frame.top
+
5,
paint);
canvas.drawRect(frame.left,
frame.top, frame.left +
5,frame.top
+
15,
paint);
//
右上角
canvas.drawRect(frame.right
-
15,
frame.top, frame.right,frame.top +
5,
paint);
canvas.drawRect(frame.right
-
5,
frame.top, frame.right,frame.top +
15,
paint);
//
左下角
canvas.drawRect(frame.left,
frame.bottom -
5,
frame.left +
15,frame.bottom,
paint);
canvas.drawRect(frame.left,
frame.bottom -
15,
frame.left +
5,frame.bottom,
paint);
//
右下角
canvas.drawRect(frame.right
-
15,
frame.bottom -
5,
frame.right,frame.bottom, paint);
canvas.drawRect(frame.right
-
5,
frame.bottom -
15,
frame.right,frame.bottom, paint);

此外将扫描线条修改为上下扫描的线,关键代码如下:

代码片段,双击复制
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
if((i
+=
5)
< frame.bottom - frame.top) {
    
   
/*
以下为用渐变线条作为扫描线 */
    
   
//
渐变图为矩形
    
   
//
mDrawable.setShape(GradientDrawable.RECTANGLE);
    
   
//
渐变图为线型
    
   
//
mDrawable.setGradientType(GradientDrawable.LINEAR_GRADIENT);
    
   
//
线型矩形的四个圆角半径
    
   
//
// mDrawable
    
   
//
// .setCornerRadii(new float[] { 8, 8, 8, 8, 8, 8, 8, 8 });
    
   
//
位置边界
    
   
//
mRect.set(frame.left + 10, frame.top + i, frame.right - 10,
    
   
//
frame.top + 1 + i);
    
   
//
设置渐变图填充边界
    
   
//
mDrawable.setBounds(mRect);
    
   
//
画出渐变线条
    
   
//
mDrawable.draw(canvas);
 
    
   
/*
以下为图片作为扫描线 */
    
   
mRect.set(frame.left
-
6,
frame.top + i -
6,
frame.right +
6,frame.top
+
6+
i);
    
   
lineDrawable.setBounds(mRect);
    
   
lineDrawable.draw(canvas);
 
    
   
//
刷新
    
   
invalidate();
    
 
}else{
    
       
i
=
0;
    
 
}

此处采用了两种线条样式,一种是渐变线条,还有一种是类似微信的图片扫描线。

详细代码请看附件源码。



运行截图如下:

 此为渐变线条 
            此为图片线条,用的是微信的图片,不过微信扫描用的应该是动画很平滑,此处用的是多次绘制



另外,扫描成功后的手机震动和提示音在BeepManager中修改,里面我额外放了两种提示音文件





示例源码工程,core包和我修改简化后的源码放都附件中



 ZXing示例源码和核心core包.rar (1010.76
KB, 下载次数: 36) 

 简化后源码.rar (2.38
MB, 下载次数: 293)

http://blog.csdn.net/xinchen200/article/details/18036695

ZXing 二维码应用的更多相关文章

  1. Atitit zxing二维码qr码识别解析

    Atitit zxing二维码qr码识别解析 1.1. qr码识别解析 by zxing1 1.2. 解码lib:qrcode.jar  2 1.3. atitit.二维码生成总结java zxing ...

  2. Android项目实战(二十八):Zxing二维码实现及优化

    前言: 多年之前接触过zxing实现二维码,没想到今日项目中再此使用竟然使用的还是zxing,百度之,竟是如此牛的玩意. 当然,项目中我们也许只会用到二维码的扫描和生成两个功能,所以不必下载完整的ja ...

  3. 程序猿媛 九:Adroid zxing 二维码3.1集成(源码无删减)

    Adroid zxing 二维码3.1集成 声明:博文为原创,文章内容为,效果展示,思路阐述,及代码片段. 转载请保留原文出处“http://my.oschina.net/gluoyer/blog”, ...

  4. 谷歌zxing 二维码生成工具

    一.加入maven依赖 <!-- 谷歌zxing 二维码 --> <dependency> <groupId>com.google.zxing</groupI ...

  5. (转载)Android项目实战(二十八):Zxing二维码实现及优化

    Android项目实战(二十八):Zxing二维码实现及优化   前言: 多年之前接触过zxing实现二维码,没想到今日项目中再此使用竟然使用的还是zxing,百度之,竟是如此牛的玩意. 当然,项目中 ...

  6. Android项目实战(四十四):Zxing二维码切换横屏扫描

    原文:Android项目实战(四十四):Zxing二维码切换横屏扫描 Demo链接 默认是竖屏扫描,但是当我们在清单文件中配置横屏显示的时候: <activity android:name=&q ...

  7. ZXing二维码生成在Unity3D中出错,数组超出界限的解决办法

    错误截图: IndexOutOfRangeException: Array index is out of range.ZXing.Color32Renderer.Render (ZXing.Comm ...

  8. Android—ZXing二维码扫描遇到的问题

    最近工作中需要开发带有二维码扫描功能的软件(基于开源项目ZXing),遇到的问题记录一下,也希望给大家带来帮助. 1.首先因为扫描要开摄像机所以加权限是一定的,不然后面什么都不能进行 <uses ...

  9. Google Zxing 二维码生成与解析

    生成二维码的开源项目可谓是琳琅满目,SwetakeQRCode.BarCode4j.Zxing...... 前端有JQuery-qrcode,同样能实现生成二维码. 选择Zxing的原因可能是对 Go ...

  10. ZXing二维码的生成和解析

    Zxing是Google提供的关于条码(一维码.二维码)的解析工具,提供了二维码的生成与解析的方法, 现在我简单介绍一下使用Java利用Zxing生成与解析二维码 注意: 二维码的生成需要借助辅助类( ...

随机推荐

  1. Java:类加载器(ClassLoader)

    听上去很高端,其实一般自定义类加载器不需要用户去实现解析的过程,只要负责实现获取类对应的.class字节流部分就ok了,摘录深入理解Java虚拟机的一段话 虚拟机设计团队把类加载阶段中的“通过一个类的 ...

  2. python中类变量和实例变量

    1. 类变量和实例变量 在Python Tutorial中对于类变量和实例变量是这样描述的: Generally speaking, instance variables are for data u ...

  3. POJ P2777 Count Color——线段树状态压缩

    Description Chosen Problem Solving and Program design as an optional course, you are required to sol ...

  4. PHP获取本地时间

    使用date ( "Y-m-d H:i:s" )函数获取当前时间,总是不对,原来默认是格林威治时间,解决的办法有两个: 1.获取之前先加   date_default_timezo ...

  5. 微信小程序-03-小程序开发框架

    微信小程序-03-小程序开发框架 官方文档: https://developers.weixin.qq.com/miniprogram/dev/framework/MINA.html 小程序开发框架 ...

  6. Ubuntu下Visual Studio Code的配置

    最近在Ubuntu系统里用Visual Studio Code编写vue代码时,在build的时候老是报错,后来发现原来Visual Studio Code里默认Tab是4个空格,而vue代码要求ta ...

  7. C# 日期和时间的字符串表示形式转换为其等效的DateTime(stringToDateTime)

    一. 标准的日期和时间字符串转换 将日期和时间的字符串表示形式转换为其等效的DateTime对象是开发中很常见的类型转换,我们最常使用的方式是: // 如果s为null,抛出ArgumentNullE ...

  8. iOS8模糊效果UIVisualEffectView的使用

    iOS8模糊效果UIVisualEffectView的使用 效果: 源码: // // ViewController.m // EffectView // // Created by XianMing ...

  9. linux 下MySQL的安装

    一.安装MySQL   1.下载源码包     从mysql官网上下载linux下的source包mysql-5.0.51b.tar.gz,注意是下载GNU tar格式的,不是rpm包.    2.解 ...

  10. Oracle SQL语句操作数字:取整、四舍五入及格式化

    用oracle sql对数字进行操作: 取上取整.向下取整.保留N位小数.四舍五入.数字格式化 取整(向下取整): select floor(5.534) from dual;select trunc ...