Python Киви не будет использовать SDL2, настаивает на использовании Pygame - PullRequest
0 голосов
/ 29 марта 2020

Я изо всех сил стараюсь Kivy (1.11.0) использовать SDL2 на Ubuntu 18.04 на рабочем столе. Это требует pygame, но это устарело, и я не хочу использовать его для нового проекта.

На бесплатном sh новом Ubuntu 18.04 VM это то, что я сделал:

~ $ sudo apt install libsdl2-dev libsdl2-image-dev mesa-common-dev python3-pip python3-venv
~ $ pip3 install --user poetry
~ $ poetry new kivytest
~ $ cd kivytest

~/kivytest $ poetry add kivy pillow
Creating virtualenv kivytest-sUhjZQq9-py3.6 in ~/.cache/pypoetry/virtualenvs
Using version ^1.11.1 for kivy
Using version ^7.0.0 for pillow

Updating dependencies
Resolving dependencies... (2.2s)

Writing lock file


Package operations: 20 installs, 0 updates, 0 removals

  - Installing certifi (2019.11.28)
  - [...]
  - Installing pillow (7.0.0)
  - Installing kivy (1.11.1)

С установленным kivy я создаю простой test.py файл:

from kivy.app import App
from kivy.uix.button import Button

class TestApp(App):
    def build(self):
        return Button(text='Hello World')

TestApp().run()

Однако, когда я запускаю его, он завершается ошибкой:

~/kivytest $ export KIVY_GL_BACKEND="sdl2"

~/kivytest $ poetry run python3 ./test.py
[INFO   ] [Logger      ] Record log in ~/.kivy/logs/kivy_20-03-29_6.txt
[INFO   ] [Kivy        ] v1.11.1
[INFO   ] [Kivy        ] Installed at "~/.cache/pypoetry/virtualenvs/kivytest-sUhjZQq9-py3.6/lib/python3.6/site-packages/kivy/__init__.py"
[INFO   ] [Python      ] v3.6.9 (default, Nov  7 2019, 10:44:02) 
[GCC 8.3.0]
[INFO   ] [Python      ] Interpreter at "~/.cache/pypoetry/virtualenvs/kivytest-sUhjZQq9-py3.6/bin/python3"
[INFO   ] [Factory     ] 184 symbols loaded
[INFO   ] [Image       ] Providers: img_tex, img_dds, img_pil, img_gif (img_pygame, img_ffpyplayer ignored)
[INFO   ] [Text        ] Provider: pil(['text_pygame'] ignored)
[CRITICAL] [Window      ] Unable to find any valuable Window provider. Please enable debug logging (e.g. add -d if running from the command line, or change the log level in the config) and re-run your app to identify potential causes
egl_rpi - ImportError: cannot import name 'bcm'
  File "~/.cache/pypoetry/virtualenvs/kivytest-sUhjZQq9-py3.6/lib/python3.6/site-packages/kivy/core/__init__.py", line 63, in core_select_lib
    fromlist=[modulename], level=0)
  File ".../kivy/core/window/window_egl_rpi.py", line 12, in <module>
    from kivy.lib.vidcore_lite import bcm, egl

pygame - ModuleNotFoundError: No module named 'pygame'
  File ".../kivy/core/__init__.py", line 63, in core_select_lib
    fromlist=[modulename], level=0)
  File ".../kivy/core/window/window_pygame.py", line 13, in <module>
    import pygame

x11 - ModuleNotFoundError: No module named 'kivy.core.window.window_x11'
  File ".../kivy/core/__init__.py", line 63, in core_select_lib
    fromlist=[modulename], level=0)

[CRITICAL] [App         ] Unable to get a Window, abort.

Как я могу заставить его использовать SDL2 ? У меня установлена ​​система SDL2 libs, установлена ​​kivy после , et c.

Это , а не дубликат подобных вопросов, касающихся Windows или Ma c OS-X , так как я запускаю его на Ubuntu и решения не применяются.

Спасибо!

1 Ответ

0 голосов
/ 29 марта 2020

Хорошо, я нашел причину - для сборки kivy с поддержкой SDL2 требуется еще несколько библиотек SDL2. Это работает:

~ $ sudo apt install mesa-common-dev \
                     libsdl2-dev libsdl2-image-dev \
                     libsdl2-ttf-dev libsdl2-mixer-dev

А затем удалите и переустановите kivy, чтобы восстановить его с поддержкой SDL2:

~/testkivy $ poetry remove kivy && poetry add kivy

Или с pip, если вы не используете poetry:

(testkivy-venv) ~ $ pip uninstall kivy && pip install --user kivy

Тогда это работает:

$ ./test.py
... 
[INFO   ] [Image       ] Providers: img_tex, img_dds, img_sdl2, img_pil, img_gif (img_ffpyplayer ignored)
[INFO   ] [Text        ] Provider: sdl2(['text_pango'] ignored)
[INFO   ] [Window      ] Provider: sdl2(['window_egl_rpi'] ignored)
[INFO   ] [GL          ] Using the "OpenGL" graphics system
[INFO   ] [GL          ] Backend used <sdl2>                         <<<< YAY!!!
[INFO   ] [GL          ] OpenGL version <b'3.0 Mesa 19.2.8'>
[INFO   ] [GL          ] OpenGL vendor <b'Intel Open Source Technology Center'>
[INFO   ] [GL          ] OpenGL renderer <b'Mesa DRI Intel(R) HD Graphics 520 (Skylake GT2) '>
[INFO   ] [GL          ] OpenGL parsed version: 3, 0
[INFO   ] [GL          ] Shading version <b'1.30'>
[INFO   ] [GL          ] Texture max size <16384>
[INFO   ] [GL          ] Texture max units <32>
[INFO   ] [Window      ] auto add sdl2 input provider
...
...