Kivy App在Android KitKat(Kivy Launcher)崩溃

时间:2017-04-26 12:16:18

标签: android android-recyclerview kivy

我的其他应用程序在Kivy Launcher上工作正常,但是这个应用程序在加载屏幕上崩溃(有时我甚至看不到崩溃前加载的文本)。由于崩溃发生在加载过程中,因此Kivy Launcher无法在MyApp/.kivy/logs中创建日志。所以我没有任何记录。

我的手机是带有Kitkat的三星S3。

我在手机上的app文件夹中复制了文件夹Python36\Lib\site-packages\kivy\uix\recycleview(可能是罪魁祸首),但我的应用仍然崩溃了。 这是应用程序(非常感谢El3phanten):

from kivy.app import App
from kivy.lang import Builder
from kivy.uix.recycleview import RecycleView
from kivy.uix.boxlayout import BoxLayout
from kivy.properties import StringProperty
from kivy.uix.recycleview.views import RecycleDataViewBehavior

items = [
    {"text": "white",    "selected": 'normal', "input_data": ["some","random","data"]},
    {"text": "lightblue","selected": 'normal', "input_data": [1,6,3]}
]

class MyViewClass(RecycleDataViewBehavior, BoxLayout):

    text = StringProperty("")
    index = None

    def set_state(self,state,app):
        app.root.ids.rv.data[self.index]['selected'] = state

    def refresh_view_attrs(self, rv, index, data):
        self.index = index
        return super(MyViewClass, self).refresh_view_attrs(rv, index, data)

class MyRecycleView(RecycleView):

    data = items

    def print_data(self,data):
        print([item['input_data'] for item in data if item['selected'] == 'down'])

KV = '''

<MyViewClass>:
    orientation: 'horizontal'
    CheckBox:
        on_state: root.set_state(self.state,app)
    Label:
        text: root.text

BoxLayout:
    orientation: 'vertical'
    MyRecycleView:
        id: rv
        viewclass: 'MyViewClass'
        RecycleBoxLayout:
            orientation: 'vertical'
            default_size: None, dp(56)
            default_size_hint: 1, None
            size_hint_y: None
            height: self.minimum_height
    Button:
        size_hint_y: 0.1
        text: "Print data"
        on_release: rv.print_data(rv.data)

'''

class Test(App):
    def build(self):
        root = Builder.load_string(KV)
        return root


Test().run()

编辑: 我现在正在获取日志。我尝试了@KeyWeeUsr解决方案,但仍未找到模块。

我的app文件夹现在以这种方式构建:

my_app/:
   -main.py
   -android.txt
   -kivy/
      -uix/
         -recycleview/
            -__init__.py
            -datamodel.py
            -layout.py
            -views.py

这是日志:

[INFO              ] Logger: Record log in /storage/emulated/0/kivy/del/.kivy/logs/kivy_17-04-27_2.txt
[INFO              ] Kivy: v1.9.1
[INFO              ] Python: v2.7.2 (default, Mar 20 2016, 23:30:13) 
[GCC 4.8]
[INFO              ] Factory: 179 symbols loaded
[WARNING           ] stderr: /data/data/org.kivy.pygame/files/lib/python2.7/site-packages/kivy/core/image/img_pygame.py:13: RuntimeWarning: import cdrom: No module named cdrom
[WARNING           ] stderr: (ImportError: No module named cdrom)
[INFO              ] Image: Providers: img_tex, img_dds, img_gif, img_pygame, img_pil (img_ffpyplayer ignored)
[WARNING           ] stderr: Traceback (most recent call last):
[WARNING           ] stderr:   File "main.py", line 3, in <module>
[WARNING           ] stderr:     from kivy.uix.recycleview import RecycleView
[WARNING           ] stderr: ImportError: No module named recycleview

3 个答案:

答案 0 :(得分:1)

我有一个使用RecyclerView的应用程序,我在Android上运行它没有问题(通过构建包,而不是复制文件夹,我使用Kivy 1.9.2dev0)

为了了解真正导致崩溃的原因,您需要在应用运行时阅读日志。

  1. 插上手机,确保通过adb devices
  2. 列出
  3. 通过adb -d install -r abc.apk
  4. 安装应用
  5. 检查日志,msg for filter是您的包名org.test.myapp
    • Mac或Linux:adb logcat | grep “msg for filter”
    • Windows:adb logcat | FINDSTR “msg for filter"
  6. 您将获得真实的日志

答案 1 :(得分:0)

在Android上运行的Kivy应用程序(甚至是启动程序)应该使用adb logcat进行调试,因为应用程序的实际输出因此甚至所有崩溃,库加载失败等等都在{{1 }}

logcat文件中提供的日志是纯Kivy日志,不包括有关APK如何启动,Window如何被拆除或者加载时是否存在问题等问题。 Python解释器本身。 →没有logcat,没有明确的解决方案。

无论如何,有一种方法可以制作自定义的Kivy Launcher:

但是需要应用第二个更改,因为启动器需要它。

但是,您可以尝试将文件夹正确放置在应用程序文件夹中,例如:

.kivy

或粘贴日志。

答案 2 :(得分:0)

对于日志,我使用应用LogCat(它需要root访问权限)

我无法让Kivy Launcher工作,因为版本仍在1.9.1

我最终不得不使用Buildozer打包应用程序(我必须使用ubuntu 17.04创建dual boot,然后安装python 3.6,kivybuildozer

我必须像这样修改buildozer.spec文件:

# comma seperated e.g. requirements = sqlite3,kivy
requirements = kivy==master

不要修改此行(即使它很诱人!):

# Kivy version to use
osx.kivy_version = 1.9.1