Скомпилированное в Emsripten приложение qt не показывает изображения - PullRequest
5 голосов
/ 04 июля 2019

У меня есть приложение для шахмат Qt. Все работает нормально, когда я собираю его с помощью компилятора VS или GCC, но у меня есть проблемы с версией веб-сборки с использованием emscripten. Когда я запускаю html с emrun, все в порядке, но изображения просто не отображаются.

Моя версия emscripten - emcc (Emscripten gcc / clang-like замена) 1.38.30 (commit d33f7a29002a2463a7956cd53a559b97a52f9560).

Моя версия qmake: QMake версия 3.1

Моя версия Qt: Использование версии Qt 5.13.0

Я использую официальные двоичные файлы Qt из онлайн-установщика linux для wasm.

Я использую команду emrun --no_browser .html для настройки сервера на локальном хосте.

Я пробовал разные типы спецификации путей. Я закончил с этим примером кода, работает нормально, но не с версией веб-сборки. Это код для загрузки примера изображения.

...
QDir::setSearchPaths("qrc", QStringList(":/"));
return QIcon(QUrl("qrc:///Images/king_white.svg").toString());

это мой файл .qrc:

<!DOCTYPE RCC><RCC version="1.0">
<qresource>
    <file>Images/king_black.svg</file>
    ...
</qresource>
</RCC>

в файле .pro у меня также есть:

RESOURCES = resources.qrc

Хорошо работает, когда я не использую emscripten. Спасибо за помощь.

EDIT: Опции сборки (из Makefile, сгенерированного qmake)

CC            = emcc
CXX           = em++
DEFINES       = -DQT_NO_DEBUG -DQT_WIDGETS_LIB -DQT_GUI_LIB -DQT_CORE_LIB
CFLAGS        = -pipe -O3 -s ALLOW_MEMORY_GROWTH=1 -Wall -W $(DEFINES)
CXXFLAGS      = -pipe -O3 -std=gnu++1y -s ALLOW_MEMORY_GROWTH=1 -Wall -W $(DEFINES)
INCPATH       = -I. -I../../Qt513/5.13.0/wasm_32/include -I../../Qt513/5.13.0/wasm_32/include/QtWidgets -I../../Qt513/5.13.0/wasm_32/include/QtGui -I../../Qt513/5.13.0/wasm_32/include/QtCore -I. -I/home/somas/.emscripten_ports/openssl/include -I../../Qt513/5.13.0/wasm_32/mkspecs/wasm-emscripten
QMAKE         = /home/somas/Qt513/5.13.0/wasm_32/bin/qmake
DEL_FILE      = rm -f
CHK_DIR_EXISTS= test -d
MKDIR         = mkdir -p
COPY          = cp -f
COPY_FILE     = cp -f
COPY_DIR      = cp -f -R
INSTALL_FILE  = install -m 644 -p
INSTALL_PROGRAM = install -m 755 -p
INSTALL_DIR   = cp -f -R
QINSTALL      = /home/somas/Qt513/5.13.0/wasm_32/bin/qmake -install qinstall
QINSTALL_PROGRAM = /home/somas/Qt513/5.13.0/wasm_32/bin/qmake -install qinstall -exe
DEL_FILE      = rm -f
SYMLINK       = ln -f -s
DEL_DIR       = rmdir
MOVE          = mv -f
TAR           = tar -cf
COMPRESS      = gzip -9f
DISTNAME      = ChessNewGeneration.js1.0.0
DISTDIR = /home/somas/ChessNewGeneration/ChessNewGeneration/.tmp/ChessNewGeneration.js1.0.0
LINK          = em++
LFLAGS        = -s WASM=1 -s FULL_ES2=1 -s USE_WEBGL2=1 -s NO_EXIT_RUNTIME=0 -s ERROR_ON_UNDEFINED_SYMBOLS=1 --bind -s "BINARYEN_TRAP_MODE='clamp'" -O3 -s ALLOW_MEMORY_GROWTH=1
LIBS          = $(SUBLIBS) /home/somas/Qt513/5.13.0/wasm_32/plugins/platforms/libqwasm.a /home/somas/Qt513/5.13.0/wasm_32/lib/libQt5EventDispatcherSupport.a /home/somas/Qt513/5.13.0/wasm_32/lib/libQt5FontDatabaseSupport.a /home/somas/Qt513/5.13.0/wasm_32/lib/libqtfreetype.a /home/somas/Qt513/5.13.0/wasm_32/lib/libQt5EglSupport.a /home/somas/Qt513/5.13.0/wasm_32/plugins/imageformats/libqgif.a /home/somas/Qt513/5.13.0/wasm_32/plugins/imageformats/libqicns.a /home/somas/Qt513/5.13.0/wasm_32/plugins/imageformats/libqico.a /home/somas/Qt513/5.13.0/wasm_32/plugins/imageformats/libqjpeg.a /home/somas/Qt513/5.13.0/wasm_32/plugins/imageformats/libqtga.a /home/somas/Qt513/5.13.0/wasm_32/plugins/imageformats/libqtiff.a /home/somas/Qt513/5.13.0/wasm_32/plugins/imageformats/libqwbmp.a /home/somas/Qt513/5.13.0/wasm_32/plugins/imageformats/libqwebp.a /home/somas/Qt513/5.13.0/wasm_32/lib/libQt5Widgets.a /home/somas/Qt513/5.13.0/wasm_32/lib/libQt5Gui.a /home/somas/Qt513/5.13.0/wasm_32/lib/libqtlibpng.a /home/somas/Qt513/5.13.0/wasm_32/lib/libqtharfbuzz.a /home/somas/Qt513/5.13.0/wasm_32/lib/libQt5Core.a /home/somas/Qt513/5.13.0/wasm_32/lib/libqtpcre2.a   
AR            = emar cqs
RANLIB        = 
SED           = sed
STRIP         = 

1 Ответ

2 голосов
/ 14 июля 2019

Я предполагаю, что "когда я не использую emscripten" означает обычный, динамически загружаемый Qt.Плагины формата изображений, включенные в такие установки, являются динамическими библиотеками и могут быть загружены по требованию Qt - это механизм, используемый для загрузки плагина формата svg, если это необходимо.

В настоящее время сборки Qms emscripten являются только статическими библиотеками.- они должны быть связаны заранее, так как они не могут быть загружены динамически при необходимости.Чтобы qmake знал, какие плагины вам понадобятся, добавьте

QTPLUGIN += qsvg

в файл проекта.Возможно, вы захотите сделать это специфичным для wasm, чтобы избежать помех на других платформах:

wasm {
    QTPLUGIN += qsvg
}
...