LoginSignup
5
6

More than 5 years have passed since last update.

Qt 5.6 LTS beta on Windows【環境変数 QT_QPA_PLATFORM_PLUGIN_PATH】

Last updated at Posted at 2016-01-08

この記事は、
QtJP月例勉強会 (Nov21,2015)
https://qt-users.doorkeeper.jp/events/34217
での成果とその後の作業を、
三鷹PGCafe月例勉強会 (Jan09,2016)
https://atnd.org/events/73218
向けに書き起こしたものです。

作業は Windows 8.1 Pro Intel 64bit 版の上で行っています。
処理系は、Visual Studio 2015 Community を使っています。
https://www.visualstudio.com/post-download-vs?sku=community

Qt 5.6 LTS とは

Qt 5.6 はQtの最新版で、2016年1月前半の時点ではbeta版に留まっています。今後RC版を経て、リリースに至ります。

Qt 5.6 は、Qtとして初めての Long Term Support バージョンとなります。
またWindows開発面からみると、Visual Studio 2015 が初めて公式にサポートされます。


Qt の読みについて
米国関係者の一部は”キューティー”と読んでいますが、公式には”キュート”です。混迷の読み問題に終止符を打つべく?2016年2月には発音記号ロゴの公式アパレルまで登場しました。
1,width=300,height=300,appearanceId=2,version=1449056614.jpg


Qt 5.6 beta の現状

Qt 5.6 beta では、ソースコードといくつかのバイナリーコードが提供されています。Visual Studio 2015 (以降 VS14 と記載)用も64/32bit共に用意されています。

ライセンスとダイナミックリンクの話

Qt では、三つの概念的ライセンス区分が示されています。

  • Commercial deployment
  • In-house deployment, private use, or student use
  • Open source distribution under a LGPL or GPL license

また実際のライセンス区分としては、二つの商用有償ライセンスと、一つの無償ライセンスが用意されています。

  • Qt for Application Development (Commercial)
  • Qt for Device Creation (Commercial)
  • Open Source

この記事では最後のオープンソースライセンスを用いますが、このライセンスでは実装にはダイナミックリンクを用いなければなりません。
iOSのようにスタティックリンクを要求されるケースでこのライセンスを用いると、全ソースコードの公開が前提となってしまいます。

この記事では、Windows環境にQt成果物をデプロイする際のダイナミックリンクに関する小ネタを扱っています。

使用したコードの入手先

cmake を セルフブートしてみよう

cmake の最新版 3.4.1 ですが、Windows向けバイナリーは32bit版しか提供されていません。そしてGUIは Qt を使用しており、ドキュメントによると4系と5系のいずれでも良いとなっています。
ここでは cmake 32bit バイナリーを使って、cmake 64bit バイナリーを作成してみました。もちろん Qt は 5.6 beta のVS14バイナリーを使います。

cmake-gui で cmakeソースコードを設定する

この図を参照して、Qtの参照先を設定してください。
(厳密にはこの図は Qt 5.6 beta を使った64bit版です。)
cmakecmake.JPG

Visual Studio 2015 でコンパイルリンク

CMake.sln ファイルが生成されていますので、これでVS14を起動します。
cmakedir.JPG

ALL_BUILD を指定して、ビルドしてください、
cmakeBuild.JPG

0 faild で終了しましたか?

新しいロードモジュールを実行してみよう。

あれ? どうも Qt のダイナミックライブラリーが見えていないようです。
cmakeGUIerr.JPG
(cmakeから提供されている32bitロードモジュールでは、Qtはスタティックリンクされているようです。)

解決策は

先のエラーダイアログを頼りに検索してみると、解決策として実行モジュールと同一ディレクトリにQtのダイナミックライブラリー群をコピーする....としている記述がほとんどです。それで解決するでしょうか?そもそもQtのダイナミックライブラリ群はちょっとした数とサイズなのですよ。

Qt 5.6 beta のダイナミックリンクなロードモジュールをWindowsで実行するには

Qt 4系の QWS(Qt Window System)に換えて、Qt 5系では QPA(Qt Platform Abstraction)という環境依存部実装を使っています。Windowsでは、Windows用のQPAモジュールを指定してやらなければいけません。
コマンドラインのオプションでも指定できますが、現実的には QT_QPA_PLATFORM_PLUGIN_PATH という環境変数で指定することになります。msvc2015_64\plugins\platforms の場所を指定してください。
QtEnv.JPG

今度は無事実行できましたね?

QT_QPA_PLATFORM_PLUGIN_PATH は誰が参照しているのか

ソースコードディレクトリの
qtbase\src\gui\kernel\qguiapplication.cpp
ファイル中の
QGuiApplicationPrivate::createPlatformIntegration()
で参照しています。

先のエラーダイアログは、同じファイルの
QGuiApplication::init_platform(....)
で出していました。

Qt 5.6 beta が参照している環境変数は

特定組込環境でしか意味をなさないものや、OS環境既定のものも含めると、266もの環境変数を参照していました。なかには、実効性の無いものも含まれているかもしれません。また Qt Creator が参照する様な実行時ではなく開発時にQtツール群が参照する環境変数も多く含まれています。

QPA に関する環境変数

  • QT_QPA_EGLFS_TSLIB
  • QT_QPA_EGLFS_WIDTH
  • QT_QPA_ENABLE_TERMINAL_KEYBOARD
  • QT_QPA_EVDEV_DEBUG
  • QT_QPA_EVDEV_KEYBOARD_PARAMETERS
  • QT_QPA_EVDEV_MOUSE_PARAMETERS
  • QT_QPA_EVDEV_TOUCHSCREEN_PARAMETERS
  • QT_QPA_FB_DISABLE_INPUT
  • QT_QPA_FB_HIDECURSOR
  • QT_QPA_FB_NO_LIBINPUT
  • QT_QPA_FB_TSLIB
  • QT_QPA_FONTDIR
  • QT_QPA_GENERIC_PLUGINS
  • QT_QPA_PLATFORM
  • QT_QPA_PLATFORM_PLUGIN_PATH
  • QT_QPA_PLATFORMTHEME
  • QT_QPA_UPDATE_IDLE_TIME
  • QT_QPA_VERBOSE

QPA 以外のQt環境変数

  • NEMO_RESOURCE_CLASS_OVERRIDE
  • PULSE_GIT_BRANCH
  • PULSE_TESTR_BRANCH
  • Q_DBUS_BLOCKING_CALL_MAIN_THREAD_WARNING_MS
  • Q_DBUS_BLOCKING_CALL_OTHER_THREAD_WARNING_MS
  • QDBUS_DEBUG
  • QDECLARATIVELANGUAGE_UPDATEERRORS
  • QMAKE
  • QMAKEFLAGS
  • QMLSCENE_DEVICE
  • QMLSCENE_IMPORT_NAME
  • QSG_ANTIALIASING_METHOD
  • QSG_DISTANCEFIELD_ANTIALIASING
  • QSG_FIXED_ANIMATION_STEP
  • QSG_RENDER_LOOP
  • QSG_RENDERER_BUFFER_STRATEGY
  • QSG_RENDERER_DEBUG
  • QSG_SANITY_CHECK
  • QSG_VISUALIZE
  • QT_ACCEL_DATADIVISOR
  • QT_ACCEL_DELIMITER
  • QT_ACCEL_FILEPATH
  • QT_ANCHORLAYOUT_NO_SIMPLIFICATION
  • QT_ANGLE_PLATFORM
  • QT_AUTH_PASSWORD
  • QT_AUTH_URL
  • QT_AUTH_USER
  • QT_AUTO_SCREEN_SCALE_FACTOR
  • QT_BEARER_POLL_TIMEOUT
  • QT_BLOCK_EVENT_LOOPS_WHEN_SUSPENDED
  • QT_COMPOSITOR_NEGATE_INVERTED_Y
  • QT_DBL_CLICK_DIST
  • QT_DEBUG_BACKINGSTORE
  • QT_DEBUG_FPS
  • QT_DEBUG_PLUGINS
  • QT_DEVICE_PIXEL_RATIO
  • QT_DIRECTFB_BLITTER_DEBUGPAINT
  • QT_DRAW_SCENE_ITEM_RECTS
  • QT_ENABLE_REGEXP_JIT
  • QT_EVENT_DISPATCHER_CORE_FOUNDATION
  • QT_EXCLUDE_GENERIC_BEARER
  • QT_FACEBOOK_ACCESS_TOKEN
  • QT_FILE_SELECTORS
  • QT_FLUSH_PAINT
  • QT_FLUSH_PAINT_EVENT
  • QT_FLUSH_UPDATE
  • QT_FONT_DPI
  • QT_GRAPHICSLAYOUT_DEBUG
  • QT_GSTREAMER_CAMERABIN_FLAGS
  • QT_GSTREAMER_CAMERABIN_SRC
  • QT_GSTREAMER_CAMERABIN_VIDEOSRC
  • QT_GSTREAMER_PLAYBIN_FLAGS
  • QT_GSTREAMER_USE_PLAYBIN_VOLUME
  • QT_GSTREAMER_WIDGET_VIDEOSINK
  • QT_GSTREAMER_WINDOW_VIDEOSINK
  • QT_HARFBUZZ
  • QT_HASH_SEED
  • QT_HAVE_TEST_FONTS
  • QT_IM_MODULE
  • QT_LABS_CONTROLS_STYLE
  • QT_LANCELOT_DIR
  • QT_LANCELOT_SERVER
  • QT_LAYOUT_DEBUG
  • QT_LOAD_TESTABILITY
  • QT_LOGGING_CONF
  • QT_LOGGING_RULES
  • QT_LOGGING_TO_CONSOLE
  • QT_MESSAGE_PATTERN
  • QT_NECESSITAS_COMPATIBILITY_LONG_PRESS
  • QT_NMEA_SERIAL_PORT
  • QT_NO_ANTIALIASING
  • QT_NO_CPU_FEATURE
  • QT_NO_FAST_MOVE
  • QT_NO_FAST_SCROLL
  • QT_NO_FT_CACHE
  • QT_NO_SUBTRACTOPAQUESIBLINGS
  • QT_ONSCREEN_PAINT
  • QT_OPENGL
  • QT_OPENGL_BUGLIST
  • QT_OPENGL_DLL
  • QT_PAN_TOUCHPOINTS
  • QT_PLUGIN_PATH
  • QT_PROXY_HOST
  • QT_PROXY_PASSWORD
  • QT_PROXY_PORT
  • QT_PROXY_USER
  • QT_QUICK_CONTROLS_STYLE
  • QT_QUICK_CORE_PROFILE
  • QT_SENSORS_LOAD_PLUGINS
  • QT_STYLE_OVERRIDE
  • QT_SUBPIXEL_AA_TYPE
  • QT_TEST_CI
  • QT_USE_ANDROID_NATIVE_DIALOGS
  • QT_USE_ANDROID_NATIVE_STYLE
  • QT_USE_NATIVE_WINDOWS
  • QT_USE_WINRT_NATIVE_DIALOGS
  • QT_VIDEONODE
  • QT_WAYLAND_CLIENT_BUFFER_INTEGRATION
  • QT_WAYLAND_DECORATION
  • QT_WAYLAND_DISABLE_WINDOWDECORATION
  • QT_WAYLAND_FORCE_DPI
  • QT_WAYLAND_IGNORE_BIND_DISPLAY
  • QT_WAYLAND_INPUTDEVICE_INTEGRATION
  • QT_WAYLAND_SERVER_BUFFER_INTEGRATION
  • QT_WAYLAND_SHELL_INTEGRATION
  • QT_WEBENGINE_USE_EXPERIMENTAL_SCREEN_CAPTURE
  • QT_WINVER_OVERRIDE (ヲイヲイ)
  • QT_XCB_GL_INTEGRATION
  • QT_XKB_CONFIG_ROOT
  • QT3DRENDER_DEBUG_LOGGING
  • QTCOMPOSE
  • QTEST_DISABLE_STACK_DUMP
  • QTEST_ENABLE_EXTRA_SELFTESTS
  • QTEST_EVENT_DELAY
  • QTEST_EXTERNAL_DEBUG
  • QTEST_EXTERNAL_RUN
  • QTEST_KEEP_IMAGEDATA
  • QTEST_KEYEVENT_DELAY
  • QTEST_MOUSEEVENT_DELAY
  • QTEST_SERIALPORT_RECEIVER
  • QTEST_SERIALPORT_SENDER
  • QTSCRIPT_TEST_CONFIG_DIR
  • QTSCRIPT_TEST_CONFIG_SUFFIX
  • QTSCRIPT_TEST_DIR
  • QTUBUNTU_ICON_THEME
  • QTUBUNTU_SWAPINTERVAL
  • QTWEBENGINE_REMOTE_DEBUGGING
  • QTWEBENGINEPROCESS_PATH
  • QV4_MM_MAX_CHUNK_SIZE
  • QV4_MM_MAXBLOCK_SHIFT
  • SHOW_EXIT_VALUE
  • STRESSDEBUG
  • tst_QProcess

OSや処理系で規定されている環境変数

  • EGL_PLATFORM
  • EGLFS_X11_SIZE
  • ENGINIO_API_URL
  • ENGINIO_CREDENTIALS_FILE_PATH
  • ENGINIO_EMAIL_ADDRESS
  • ENGINIO_LOGIN_PASSWORD
  • LC_ALL
  • LC_CTYPE
  • LC_MEASUREMENT
  • LC_MESSAGES
  • LC_MONETARY
  • LC_NUMERIC
  • LC_TIME
  • BROWSER
  • DEFAULT_BROWSER
  • DESKTOP_SESSION
  • DESKTOP_STARTUP_ID
  • DISPLAY
  • DXSDK_DIR
  • DYLD_LIBRARY_PATH
  • GRID_UNIT_PX
  • IBUS_ENABLE_SYNC_MODE
  • KDE_SESSION_VERSION
  • KDEDIRS
  • KDEHOME
  • LANG
  • LD_LIBRARY_PATH
  • ORIENTATION
  • TZ
  • UNICODEMAP_JP
  • XCOMPOSEFILE
  • XCURSOR_SIZE
  • XCURSOR_THEME
  • XDG_CACHE_HOME
  • XDG_CONFIG_DIRS
  • XDG_CONFIG_HOME
  • XDG_CURRENT_DESKTOP
  • XDG_DATA_DIRS
  • XDG_DATA_HOME
  • XDG_RUNTIME_DIR
  • BT_TEST_DEVICE
  • DBUS_SESSION_BUS_ADDRESS
  • GIT_BRANCH
  • JAVA_HOME
  • JENKINS_HOME
  • PlatformToolset
  • QUERY_STRING
  • RESOURCE_NAME
  • SENSORLOG
  • TSLIB_TSDEVICE
  • XMLPATTERNSXQTS_TESTRANGE
  • ExtensionSdkDir
  • ProgramFiles
  • SystemDrive
  • SystemRoot
  • UCRTVersion
  • VCInstallDir
  • windir
  • WindowsSdkDir
  • all_proxy
  • ftp_proxy
  • http_proxy
  • https_proxy
  • no_proxy
  • APPDATA
  • COMPUTERNAME
  • COMSPEC
  • HOME
  • HOMEDRIVE
  • HOMEPATH
  • PATH
  • PATHEXT
  • PROMPT
  • TEMP
  • TMP
  • TMPDIR
  • USERPROFILE

組込み向けと思われる環境変数

  • MINISTRO_ANDROID_STYLE_PATH
  • MINISTRO_SSL_CERTS_PATH
  • NATIVEDEBUG
  • NATIVEDEBUGSPEED
  • QQNX_DISABLE_POWER_SAVE
  • QQNX_DISPLAY_DEPTH
  • QQNX_PHYSICAL_SCREEN_SIZE
  • QQNX_RENDERER_DEFAULT_AUDIO_SINK
  • QT_ANDROID_APP_ICON_SIZE
  • QT_ANDROID_DISABLE_GLYPH_CACHE_WORKAROUND
  • QT_ANDROID_FONT_LOCATION
  • QT_ANDROID_FONTS
  • QT_ANDROID_FONTS_MONOSPACE
  • QT_ANDROID_FONTS_SERIF
  • QT_ANDROID_MAX_ASSETS_CACHE_SIZE
  • QT_ANDROID_MAX_PREPOPULATED_ASSETS_CACHE_SIZE
  • QT_ANDROID_MINIMUM_MOUSE_DOUBLE_CLICK_DISTANCE
  • QT_ANDROID_RASTER_IMAGE_DEPTH
  • QT_ANDROID_THEME
  • QT_ANDROID_THEME_DISPLAY_DPI

参考文献

5
6
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
5
6