Funcția proiectului recent necesită utilizarea scanării codurilor QR. Mă refer la proiectul open source al Google, ZXing: După finalizarea funcției: Am constatat că nu a fost nicio problemă la scanarea codului de bare: Dar când scanezi codul QR, unele dintre ele sunt distorsionate: Sau nu este o întrebare chineză: Am citit multe informații pe Internet. Dar efectul tot nu este ideal: Ulterior, s-a constatat că, atâta timp cât este codificat în formatul ISO-8859-1, rezultatul este eliminat și apoi convertit corespunzător: Problema este rezolvată. Nu trebuie să modifici codul sursă: iată cum se face
În primul rând: Mai întâi setează codarea implicită în clasa CaptureActivity
- decodeFormats = null;
- characterSet = "ISO-8859-1";
Cod de copiere
În al doilea rând: Converti codarea corespunzătoare în activitatea care preia rezultatul. Iată-mă, lucrând la asta în clasa ResultActivity
- public class ResultActivity extends Activity implements OnClickListener{
- private TextView dec_result;
- private String resultStr;
- private ImageView codeImage;
- private Button returnChoujiang,returnJubao;
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- // TODO Auto-generated method stub
- super.onCreate(savedInstanceState);
- setContentView(R.layout.dec_result);
- init();
- dec_result=(TextView)findViewById(R.id.dec_result);
- codeImage=(ImageView)findViewById(R.id.code_image);
- Intent intent=getIntent();
- resultStr=intent.getStringExtra("result");
- String UTF_Str="";
- String GB_Str="";
- boolean is_cN=false;
- try {
- System.out.println("------------"+resultStr);
- UTF_Str=new String(resultStr.getBytes("ISO-8859-1"),"UTF-8");
- System.out.println("这是转了UTF-8的"+UTF_Str);
- is_cN=IsChineseOrNot.isChineseCharacter(UTF_Str);
- //防止有人特意使用乱码来生成二维码来判断的情况
- boolean b=IsChineseOrNot.isSpecialCharacter(resultStr);
- if(b){
- is_cN=true;
- }
- System.out.println("是为:"+is_cN);
- if(!is_cN){
- GB_Str=new String(resultStr.getBytes("ISO-8859-1"),"GB2312");
- System.out.println("这是转了GB2312的"+GB_Str);
- }
- } catch (UnsupportedEncodingException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
-
-
- Bitmap bm=intent.getParcelableExtra("IMG_return");
- if(is_cN){
- dec_result.setText(UTF_Str);
- }else{
- dec_result.setText(GB_Str);
- }
- codeImage.setImageBitmap(bm);
-
- returnChoujiang.setOnClickListener(this);
- returnJubao.setOnClickListener(this);
- }
Cod de copiere
În al treilea rând: următorul lucru este pentru a judeca dacă se află în codarea Unicode
- public class IsChineseOrNot {
-
- public static final boolean isChineseCharacter(String chineseStr) {
- char[] charArray = chineseStr.toCharArray();
- for (int i = 0; i < charArray.length; i++) {
- //是否是Unicode编码,除了"�"这个字符.这个字符要另外处理
- if ((charArray[i] >= '\u0000' && charArray[i] < '\uFFFD')||((charArray[i] > '\uFFFD' && charArray[i] < '\uFFFF'))) {
- continue;
- }
- else{
- return false;
- }
- }
- return true;
- }
-
- public static final boolean isSpecialCharacter(String str){
- //是"�"这个特殊字符的乱码情况
- if(str.contains("�")){
- return true;
- }
- return false;
- }
- }
Cod de copiere
În cele din urmă, acest lucru rezolvă problema distorsionată chinezească a ZXing-ului
|