Funktionen af det nylige projekt kræver brug af scanning af QR-koder. Jeg henviser til Googles open source-projekt ZXing: Når funktionen er fuldført: Jeg fandt ud af, at der ikke var noget problem med at scanne stregkoden: Men når man scanner QR-koden, er nogle af dem utydelige: Eller ikke et kinesisk spørgsmål: Jeg henviste til en masse information på internettet. Men effekten er stadig ikke ideel: Senere blev det konstateret, at så længe det er kodet i ISO-8859-1-formatet, fjernes resultatet og konverteres derefter tilsvarende: Problemet er løst. Du behøver ikke ændre kildekoden: her er, hvordan du gør det
Først: Først sæt dens standardkodning i CaptureActivity-klassen
- decodeFormats = null;
- characterSet = "ISO-8859-1";
Kopier kode
For det andet: Du konverterer den tilsvarende kodning i aktiviteten, der henter resultatet. Her arbejder jeg på det i ResultActivity-klassen
- 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);
- }
Kopier kode
For det tredje: Følgende er at vurdere, om det er i Unicode-kodning
- 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;
- }
- }
Kopier kode
Endelig løser dette det kinesiske forvredne problem med ZX-ing
|