01-01 08:11:27.038 E/StrictMode( 2641): Tried to access the API:ViewConfiguration which needs to have proper configuration from a non-UI Context:com.android.camera.app.CameraApp@32d9eff The API:ViewConfiguration needs a proper configuration. Use UI contexts such as an activity or a context created via createWindowContext(Display, int, Bundle) or createConfigurationContext(Configuration) with a proper configuration. 01-01 08:11:27.038 E/StrictMode( 2641): java.lang.IllegalAccessException: Tried to access the API:ViewConfiguration which needs to have proper configuration from a non-UI Context:com.android.camera.app.CameraApp@32d9eff 01-01 08:11:27.038 E/StrictMode( 2641): at android.os.StrictMode.assertConfigurationContext(StrictMode.java:2296) 01-01 08:11:27.038 E/StrictMode( 2641): at android.view.ViewConfiguration.get(ViewConfiguration.java:521) 01-01 08:11:27.038 E/StrictMode( 2641): at android.view.View.<init>(View.java:5321) 01-01 08:11:27.038 E/StrictMode( 2641): at android.widget.ImageView.<init>(ImageView.java:181) 01-01 08:11:27.038 E/StrictMode( 2641): at com.android.camera.data.PhotoItem.getView(PhotoItem.java:127) 01-01 08:11:27.038 E/StrictMode( 2641): at com.android.camera.data.CameraFilmstripDataAdapter.getView(CameraFilmstripDataAdapter.java:151) 01-01 08:11:27.038 E/StrictMode( 2641): at com.android.camera.widget.FilmstripView.buildViewItemAt(FilmstripView.java:850) 01-01 08:11:27.038 E/StrictMode( 2641): at com.android.camera.widget.FilmstripView.reload(FilmstripView.java:1827) 01-01 08:11:27.038 E/StrictMode( 2641): at com.android.camera.widget.FilmstripView.access$1300(FilmstripView.java:58) 01-01 08:11:27.038 E/StrictMode( 2641): at com.android.camera.widget.FilmstripView$3.onFilmstripItemLoaded(FilmstripView.java:1567) 01-01 08:11:27.038 E/StrictMode( 2641): at com.android.camera.data.CameraFilmstripDataAdapter.replaceItemList(CameraFilmstripDataAdapter.java:276) 01-01 08:11:27.038 E/StrictMode( 2641): at com.android.camera.data.CameraFilmstripDataAdapter.access$700(CameraFilmstripDataAdapter.java:39) 01-01 08:11:27.038 E/StrictMode( 2641): at com.android.camera.data.CameraFilmstripDataAdapter$QueryTask.onPostExecute(CameraFilmstripDataAdapter.java:447) 01-01 08:11:27.038 E/StrictMode( 2641): at com.android.camera.data.CameraFilmstripDataAdapter$QueryTask.onPostExecute(CameraFilmstripDataAdapter.java:379) 01-01 08:11:27.038 E/StrictMode( 2641): at android.os.AsyncTask.finish(AsyncTask.java:771) 01-01 08:11:27.038 E/StrictMode( 2641): at android.os.AsyncTask.access$900(AsyncTask.java:199) 01-01 08:11:27.038 E/StrictMode( 2641): at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:788) 01-01 08:11:27.038 E/StrictMode( 2641): at android.os.Handler.dispatchMessage(Handler.java:106) 01-01 08:11:27.038 E/StrictMode( 2641): at android.os.Looper.loopOnce(Looper.java:201) 01-01 08:11:27.038 E/StrictMode( 2641): at android.os.Looper.loop(Looper.java:288) 01-01 08:11:27.038 E/StrictMode( 2641): at android.app.ActivityThread.main(ActivityThread.java:7870) 01-01 08:11:27.038 E/StrictMode( 2641): at java.lang.reflect.Method.invoke(Native Method) 01-01 08:11:27.038 E/StrictMode( 2641): at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:548) 01-01 08:11:27.038 E/StrictMode( 2641): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1003)
时间: 2024-04-19 13:23:26 浏览: 544
根据报错信息,可以看出问题是在相机应用中使用了非 UI 上下文(non-UI Context)来访问 ViewConfiguration API,导致了 IllegalAccessException 异常。
这个错误可能是由于相机应用在非 UI 上下文中尝试访问 UI 相关的 API 导致的。UI 相关的操作通常需要在活动(Activity)或以正确配置创建的上下文中进行,而不是在后台线程或其他非 UI 上下文中。
为了解决这个问题,你可以尝试以下几个方法:
1. 确保在相机应用中的任何操作都在正确的 UI 上下文中进行。如果你在后台线程中执行操作,确保正确地切换到主线程来执行与 UI 相关的操作。
2. 检查相机应用的代码,确保没有在非 UI 上下文中访问 UI 相关的 API。检查是否有在异步任务(AsyncTask)或其他后台线程中执行的代码尝试访问 UI 相关的 API。
3. 如果你无法确定问题出在哪个部分,可以尝试使用调试工具(如 Android Studio)对相机应用进行调试,并观察在哪个代码段出现了异常。
4. 如果你是相机应用的开发者,可以参考 Android 文档和开发者指南,了解如何正确处理 UI 相关的操作和上下文。确保在正确的上下文中执行 UI 操作,或者使用合适的方法传递正确的上下文。
5. 如果你是应用的用户,尝试卸载并重新安装相机应用,或者尝试使用其他相机应用作为替代。
请注意,具体解决方法可能因相机应用的实现方式和代码结构而有所差异。如果问题仍然存在,你可能需要向相机应用的开发者寻求更具体的帮助和支持。
相关问题
android.os.strictmode.DiskReadViolation at android.os.StrictMode$AndroidBlockGuardPolicy.onReadFromDisk(StrictMode.java:1596) at libcore.io.BlockGuardOs.open(BlockGuardOs.java:249) at libcore.io.ForwardingOs.open(ForwardingOs.java:166) at android.app.ActivityThread$AndroidOs.open(ActivityThread.java:7844) at libcore.io.MemoryMappedFile.mmapRO(MemoryMappedFile.java:54) at libcore.timezone.ZoneInfoDb.loadData(ZoneInfoDb.java:185) at libcore.timezone.ZoneInfoDb.loadTzDataWithFallback(ZoneInfoDb.java:119) at libcore.timezone.ZoneInfoDb.<clinit>(ZoneInfoDb.java:46) at java.util.TimeZone.getTimeZone(TimeZone.java:579) at java.util.TimeZone.getDefaultRef(TimeZone.java:724) at java.util.TimeZone.getDefault(TimeZone.java:700) at java.text.SimpleDateFormat.initializeCalendar(SimpleDateFormat.java:743) at java.text.SimpleDateFormat.<init>(SimpleDateFormat.java:687) at java.text.SimpleDateFormat.<init>(SimpleDateFormat.java:666) at com.hryt.remoter.uimce.app.CrashHandler.<init>(CrashHandler.java:53) at com.hryt.remoter.uimce.app.CrashHandler.<clinit>(CrashHandler.java:49) at com.hryt.remoter.uimce.app.CrashHandler.getInstance(CrashHandler.java:65) at com.hryt.remoter.uimce.app.RemoterApplication.onCreate(RemoterApplication.java:32) at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:1192) at android.app.ActivityThread.handleBindApplication(ActivityThread.java:7013) at android.app.ActivityThread.access$1300(ActivityThread.java:238) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1921) at android.os.Handler.dispatchMessage(Handler.java:106) at android.os.Looper.loop(Looper.java:223) at android.app.ActivityThread.main(ActivityThread.java:7958) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:603) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947)
这个堆栈跟踪信息显示出现了一个严格模式的磁盘读取违规问题,可能是在读取磁盘文件时出现了问题。关于为什么会出现这个问题,需要根据具体的应用程序代码来进行分析,但是建议你检查一下是否在主线程中进行了磁盘读取操作,因为在 Android 应用程序中进行耗时的 I/O 操作可能会导致主线程阻塞,从而导致 ANR(应用程序无响应)错误。另外,你可以尝试使用异步任务或者线程池等方式来执行磁盘读取操作,以避免阻塞主线程。同时,也可以在应用程序的代码中添加 try-catch 块来捕获可能出现的异常,以避免应用程序崩溃。
E/AndroidRuntime: FATAL EXCEPTION: main Process: com.example.test_differ_kalman, PID: 32648 android.os.NetworkOnMainThreadException at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1668) at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:389) at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:230) at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:212) at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:436) at java.net.Socket.connect(Socket.java:621) at com.example.poslib.PosLib.startThread(PosLib.java:197) at com.example.test_differ_kalman.MyFragment$1.onClick(MyFragment.java:48)
根据您提供的错误日志,可以看出发生了 `android.os.NetworkOnMainThreadException` 异常。这个异常通常在主线程上执行了网络操作时抛出,因为在 Android 中,主线程主要用于处理 UI 相关的操作,不允许在主线程上执行耗时的网络请求。
解决这个问题的常见方法是将网络操作放在后台线程中执行,以避免阻塞主线程。您可以使用 `Thread`、`Handler` 或者 `AsyncTask` 等方式来在后台线程中执行网络连接操作。
以下是一个使用 `Thread` 的示例代码:
```java
new Thread(new Runnable() {
@Override
public void run() {
try {
Socket socket = new Socket();
socket.connect(new InetSocketAddress(mServerIp, mServerPort));
// 在这里执行与基站的通信操作
} catch (IOException e) {
e.printStackTrace();
}
}
}).start();
```
请将您的网络连接代码放在上述示例中的注释部分进行替换,并确保在点击事件处理方法 `MyFragment$1.onClick()` 中调用这段代码。
通过将网络连接操作放在后台线程中执行,可以避免 `NetworkOnMainThreadException` 异常,并提高应用的响应性和稳定性。
阅读全文
相关推荐
















