我的其他应用程序在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
答案 0 :(得分:1)
我有一个使用RecyclerView的应用程序,我在Android上运行它没有问题(通过构建包,而不是复制文件夹,我使用Kivy 1.9.2dev0)
为了了解真正导致崩溃的原因,您需要在应用运行时阅读日志。
adb devices
adb -d install -r abc.apk
msg for filter
是您的包名org.test.myapp
adb logcat | grep “msg for filter”
adb logcat | FINDSTR “msg for filter"
答案 1 :(得分:0)
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,kivy和buildozer)
我必须像这样修改buildozer.spec文件:
# comma seperated e.g. requirements = sqlite3,kivy
requirements = kivy==master
不要修改此行(即使它很诱人!):
# Kivy version to use
osx.kivy_version = 1.9.1