Pyjnius: "فقط الخيط الأصلي الذي أنشأ عرضًا هرميًا يمكنه لمس طرق العرض الخاصة به." خطأ عند محاولة الوصول إلى طرق android.view.Window

تم إنشاؤها على ١٥ ديسمبر ٢٠١٨  ·  1تعليق  ·  مصدر: kivy/pyjnius

from kivy.app import App
from kivy.uix.relativelayout import RelativeLayout
from jnius import autoclass

CurrentActivity  = autoclass('org.kivy.android.PythonActivity').mActivity
view = CurrentActivity.getWindow().getDecorView()
view.setKeepScreenOn(True)

class Root(RelativeLayout):
    def __init__(self):
        super().__init__()

class SomeApp(App):
    def build(self):
        return Root()

SomeApp().run()

يحدث الخطأ نفسه عند استخدام طريقة مختلفة android.view.Window :

CurrentActivity  = autoclass('org.kivy.android.PythonActivity').mActivity
WindowManager = autoclass('android.view.WindowManager$LayoutParams')
CurrentActivity.getWindow().addFlags(WindowManager.FLAG_KEEP_SCREEN_ON)
Kivy 1.10.1
Python 3.6
12-15 16:48:21.692 18623 18646 I python  :  Traceback (most recent call last):
12-15 16:48:21.692 18623 18646 I python  : WARNING:kivy:stderr: Traceback (most recent call last):
12-15 16:48:21.693 18623 18646 I python  :    File "main.py", line 20, in <module>
12-15 16:48:21.693 18623 18646 I python  : WARNING:kivy:stderr:   File "main.py", line 20, in <module>
12-15 16:48:21.694 18623 18646 I python  :      view.setKeepScreenOn(True)
12-15 16:48:21.694 18623 18646 I python  : WARNING:kivy:stderr:     view.setKeepScreenOn(True)
12-15 16:48:21.695 18623 18646 I python  :    File "jnius/jnius_export_class.pxi", line 734, in jnius.JavaMethod.__call__ (jnius/jnius.c:25894)
12-15 16:48:21.695 18623 18646 I python  : WARNING:kivy:stderr:   File "jnius/jnius_export_class.pxi", line 734, in jnius.JavaMethod.__call__ (jnius/jnius.c:25894)
12-15 16:48:21.697 18623 18646 I python  :    File "jnius/jnius_export_class.pxi", line 828, in jnius.JavaMethod.call_method (jnius/jnius.c:27082)
12-15 16:48:21.697 18623 18646 I python  : WARNING:kivy:stderr:   File "jnius/jnius_export_class.pxi", line 828, in jnius.JavaMethod.call_method (jnius/jnius.c:27082)
12-15 16:48:21.698 18623 18646 I python  :    File "jnius/jnius_utils.pxi", line 93, in jnius.check_exception (jnius/jnius.c:4012)
12-15 16:48:21.698 18623 18646 I python  : WARNING:kivy:stderr:   File "jnius/jnius_utils.pxi", line 93, in jnius.check_exception (jnius/jnius.c:4012)
12-15 16:48:21.699 18623 18646 I python  :  jnius.JavaException: JVM exception occurred: Only the original thread that created a view hierarchy can touch its views.
12-15 16:48:21.699 18623 18646 I python  : WARNING:kivy:stderr: jnius.JavaException: JVM exception occurred: Only the original thread that created a view hierarchy can touch its views.
12-15 16:48:21.822 18623 18646 I python  : Python for android ended.
12-15 16:48:21.830 18623 18623 V SDL     : onWindowFocusChanged(): false
12-15 16:48:21.833 18623 18623 V PythonActivity: onPause()
12-15 16:48:21.833 18623 18623 V SDL     : onPause()
12-15 16:48:21.833 18623 18623 V SDL     : nativePause()
12-15 16:48:21.833 18623 18623 F libc    : Fatal signal 11 (SIGSEGV), code 1, fault addr 0x0 in tid 18623 (ample.myaasdqpp)
support upstream

التعليق الأكثر فائدة

يعني الخطأ أساسًا أنك تقوم بتشغيل PyJNIus ، والتطبيق الخاص بك ، في Thread غير رئيسي وهو السلوك الافتراضي لنظام android ، على ما أعتقد. صححني إذا كنت مخطئا.

تخيلها مثل حلقة Kivy الرئيسية التي تقوم باستطلاعات الرأي لمختلف الأحداث وما تحاول القيام به هو sleep(1) . بشكل افتراضي ، يمكنك تجميد واجهة المستخدم الخاصة بك في Kivy ما لم تستخدم kivy.clock.Clock ، ولكن ما يفعله Android هو أنه لا يسمح لك بفعل أي شيء من هذا القبيل. ستحتاج إلى تشغيل الكود الخاص بك بشكل صريح على Thread عبر java.lang.Runnable و android.app.Activity.runOnUiThread ، على سبيل المثال مثل هذا المثال .

أو يمكنك فقط استيراد السلوك من الحزمة android في android.runnable.run_on_ui_thread ، لكن لا تنس إضافته إلى متطلباتك أيضًا!

>كل التعليقات

يعني الخطأ أساسًا أنك تقوم بتشغيل PyJNIus ، والتطبيق الخاص بك ، في Thread غير رئيسي وهو السلوك الافتراضي لنظام android ، على ما أعتقد. صححني إذا كنت مخطئا.

تخيلها مثل حلقة Kivy الرئيسية التي تقوم باستطلاعات الرأي لمختلف الأحداث وما تحاول القيام به هو sleep(1) . بشكل افتراضي ، يمكنك تجميد واجهة المستخدم الخاصة بك في Kivy ما لم تستخدم kivy.clock.Clock ، ولكن ما يفعله Android هو أنه لا يسمح لك بفعل أي شيء من هذا القبيل. ستحتاج إلى تشغيل الكود الخاص بك بشكل صريح على Thread عبر java.lang.Runnable و android.app.Activity.runOnUiThread ، على سبيل المثال مثل هذا المثال .

أو يمكنك فقط استيراد السلوك من الحزمة android في android.runnable.run_on_ui_thread ، لكن لا تنس إضافته إلى متطلباتك أيضًا!

هل كانت هذه الصفحة مفيدة؟
0 / 5 - 0 التقييمات