第一种解决方案:
此方法不止对U8220有效,同样对其他android手持设备logcat无信息输出有效.
问题表现:连接手机与电脑后,保证驱动安装争取,debug模式打开,在ddms中可以看到进程信息,但是logcat中无信息输出问题原因:一些rom默认关闭logcat
问题说明:ddms中设备名字显示为问号不影响,即adb get-serialno显示为问号不影响.
解决方法:
1.需要root权限(部分rom不需要)
2.打开logcat,并设置level
adb shell
echo 1 > /sys/kernel/logger/log_main/enable // 这里为注释,将1写入开关文件,1为开,0为关
echo 2 >/sys/kernel/logger/log_main/priority // 里为注释,将代表level的2写入优先级文件
3.重启adb,如果使用eclipse,先关闭eclipse,再重启adb,再启动eclipse
adb kill-server
adb start-server
4.此时70%的logcat应该能正常工作了.如果此时logcat仍旧不工作,更新adb(只是一条指令,不需联网,很快执行完毕)
android update adb
5.重复第3步.此时80%的logcat应该能正常工作了
6.如果logcat仍旧不工作
找到个人主目录下的android目录,如我的是C:\Documents and Settings\lypoint\.android
找到这个目录下的adb_usb.ini文件,其内容默认只有三行,全为注释,在后面添加一行,内容为0x12d1
7.重复第三步,此时90%的logcat应该能正常工作了
第二种解决方案:
这个错误是和调用相机摄像头相关的。
产生这个错误的原因主要在于代码控制分辨率的显示和真机测试分辨率不一样。
一:解决办法
WindowManager wm = (WindowManager) getSystemService(Context.WINDOW_SERVICE);
Display display = wm.getDefaultDisplay();
Camera.Parameters parameters = camera.getParameters();// 得到摄像头的参数
parameters.setPreviewSize(display.getWidth(),display.getHeight());注释掉这两句
parameters.setPictureSize(display.getHeight(),display.getWidth());注释掉这两句
二:有可能你的真机是属于定制机,或者深度开发过,对camera对了不少的改动。
camera.setParameters(parameters);//导致不能使用这个方法了,注释掉这一行吧。
但是这样的话,设置的一些参数就不能使用了,目前还没解决,求高手赐教。