проблема
Я могу загрузить фотографии с помощью модуля Image()
в киве. Это , как я смог установить KIVY, чтобы я мог просматривать файлы TIFF. Но теперь каждый раз, когда я загружаю изображение в формате TIFF, я получаю несколько всплывающих предупреждений одно за другим, прерывая работу программы.
TIFFReadDirectory warning:
unknown field with tag 18246 (0x4746)
TIFFReadDirectory warning:
unknown field with tag 18249 (0x4749)
TIFFReadDirectory warning:
unknown field with tag 20752 (0x5110)
TIFFReadDirectory warning:
unknown field with tag 20753 (0x5111)
TIFFReadDirectory warning:
unknown field with tag 20754 (0x5112)
TIFFReadDirectory warning:
unknown field with tag 40092 (0x9c9c)
TIFFReadDirectory warning:
unknown field with tag 40093 (0x9c9d)
TIFFReadDirectory warning:
unknown field with tag 40094 (0x9c9e)
Чтобы уточнить, ни одно из этих предупреждений не появляется в журнале Python. Это все отдельные поля предупреждений, которые появляются перед тем, как моя программа отображает файл TIFF. Я слышал, что библиотека с именем libtiff имеет тенденцию вызывать эту проблему.
код
from kivy.app import App
from kivy.uix.boxlayout import BoxLayout
from kivy.clock import Clock
from kivy.uix.image import Image
class ContainerBox(BoxLayout):
def __init__(self, **kwargs):
super(ContainerBox, self).__init__(**kwargs)
self.orientation = 'vertical'
self.picture = Image(allow_stretch=True, source='..\pics\snorlax.tif')
Clock.schedule_once(lambda dt: self.add_widget(self.picture), timeout=0.1)
class SimpleImage(App):
def build(self):
return ContainerBox()
if __name__ == '__main__':
SimpleImage().run()
технические подробности
- Изображения можно загрузить здесь .
- Я изменил данные exif этого файла. Возможно, я добавил пару нестандартных тегов в файл. Но я сделал то же самое с файлами jpg и png. Это не вызывало раздражающих всплывающих окон, подобных этому.
- Я использую Kivy версии 1.11.1
- Согласно Anaconda, виртуальная среда работает под управлением Python 3.5.6
- Iя запускаю это через PyCharm на Windows 7
- Вот подробности из журнала Python:
[INFO ] [deps ] Successfully imported "kivy_deps.glew" 0.1.12
[INFO ] [deps ] Successfully imported "kivy_deps.sdl2" 0.1.22
[INFO ] [Kivy ] v1.11.1
[INFO ] [Kivy ] Installed at "C:\Users\H\venvs\env1\lib\site-packages\kivy\__init__.py"
[INFO ] [Python ] v3.6.0 (v3.6.0:41df79263a11, Dec 23 2016, 08:06:12) [MSC v.1900 64 bit (AMD64)]
[INFO ] [Python ] Interpreter at "C:\Users\H\venvs\env1\Scripts\python.exe"
[INFO ] [Factory ] 184 symbols loaded
[INFO ] [Image ] Providers: img_tex, img_dds, img_sdl2, img_gif (img_pil, img_ffpyplayer ignored)
[INFO ] [Loader ] using a thread pool of 2 workers
[INFO ] [Text ] Provider: sdl2
[INFO ] [Window ] Provider: sdl2
[INFO ] [GL ] Using the "OpenGL" graphics system
[INFO ] [GL ] Backend used <sdl2>
[INFO ] [GL ] OpenGL version <b'4.0.0 - Build 9.18.10.3204'>
[INFO ] [GL ] OpenGL vendor <b'Intel'>
[INFO ] [GL ] OpenGL renderer <b'Intel(R) HD Graphics 4600'>
[INFO ] [GL ] OpenGL parsed version: 4, 0
[INFO ] [GL ] Shading version <b'4.00 - Build 9.18.10.3204'>
[INFO ] [GL ] Texture max size <8192>
[INFO ] [GL ] Texture max units <16>
[INFO ] [Window ] auto add sdl2 input provider
мой вопрос к вам
ЭтоМожно ли подавить эти предупреждения? Я думаю, что они генерируются какой-то библиотекой, которую зовет Киви. Это может быть даже скомпилированный код, который я не могу редактировать.
Я потратил очень много времени на создание сложного пользовательского интерфейса с Kivy. И я действительно не хочу выбрасывать всю эту работу. Но я мог бы захотеть перенести его на c ++, где теоретически мог бы контролировать больше кода. Это необходимо или даже возможно?