このメソッドは、Visual Studio 2013 で動作することがテストされています。Visual Studio 2012 および 2013 を使用したビルド済みのバイナリは、OpenGL バージョンを含めて、こちらから入手できます。
ステップ 1: セットアップ
ここからRapidEE をダウンロードしてインストールします。RapidEE は、Windows 環境変数エディターです。これは、このプロセスの残りの部分に非常に役立ちます (そして一般的に)。
DirectX 11 SDK をインストールします。これは現在 Windows 8 SDK の一部であるため、最初にここから入手できる DirectX 10 SDK をインストールする必要があります(ただし、次の文の警告を参照してください)。Visual C++ 2010 再頒布可能パッケージがインストールされていて、おそらくインストールされている場合 (VS 2010 と共に自動的にインストールされます)、ここで説明されている手順に従って、DirectX 10 のインストールを支援してください。DirectX 10 SDK をインストールしたら、DirectX 11 SDKを含むWindows 8 SDK をダウンロードしてインストールします。 はい、これは面倒ですが、DirectX 11 SDK を持っていることがわかっていない限り、Qt ビルドは失敗します。
Python.orgまたはAnaconda Pythonから Python for Windows (3.3 で動作する 2.6+ を聞いたことがあります) をインストールします。
ActiveStateから Perl for Windows をインストールします。
ステップ 2: Git (およびビルド) Qt5 (はい、つまり Git を意味します)
qt-project の Web サイトにあるWindows のインストール ガイドに従ってください。
概要
上記のリンクと次のメモの詳細を要約すると (エラーがある場合は、次のメモを参照してください。回答がある場合があります)。
ビルド エラーを回避するために、Avast をアンインストールします (これがインストールされている場合)。はい、文字通りそれをアンインストールすることを意味します。システムから 100% 削除してください。 非アクティブ化は機能しません。以下の詳細なメモを参照してください。
最初のステップの注意git
: 以下の最初のプルにSmartGit を使用しないでください (自分が何をしているのか本当にわかっている場合を除きます) 。
Git for Windowsがインストールされている必要があります。
Qt
インストールを配置する場所とcd
、任意のコマンド プロンプト ウィンドウからの新しいインストールを含むディレクトリを決定します。(このプロセスは非常に脆弱でエラーが発生しやすいため、個人的には に直接入れていますがC:
、これはおそらく必要ありません)。
上記のディレクトリから、次を実行します。
git clone git://gitorious.org/qt/qt5.git qt5
これは速いです。完了すると、'stable' ブランチにいるはずですが、念のため、新しく作成されたディレクトリに ing したgit checkout stable
後はいつでも実行できます。VS2013 64bitで動作確認済みです。cd
qt5
git checkout 5.4.1
次の手順に進む前に、現在のコマンド プロンプト ウィンドウを閉じます(Visual Studio コマンド プロンプト ウィンドウでない場合)。これは、次の手順で Visual Studio コマンド プロンプト ウィンドウを使用していることを確認するためです。
次に、32 ビット (x86) または 64 ビットの VS Tools コマンド プロンプトを実行します (Qt5 を 32 ビットまたは 64 ビットのどちらでビルドしているかによって異なります)。これにアクセスするには、[スタート] メニューから見つける必要があります - Program Files
-> [Microsoft] Visual Studio 2012/2013
->Visual Studio Tools
に移動すると、面白い名前でそこに表示されます。名前には次のフレーズを含める必要がありますNative Tools
。32 ビット バージョンx86
の名前には が含まれ、64 ビット バージョンx64
の名前には が含まれます。
cd
上記の手順で新しく作成したqt5
ディレクトリに移動します。
Visual Studio コマンド プロンプト内から、残りの Qt サブモジュールをダウンロードする必要があります。
perl ./init-repository --no-webkit
大量のダウンロードが必要なため、このステップの実行には少し時間がかかりますが、まともな接続ではそれほどひどいものではありません。
次に、ダウンロードされない残りの OPTIONAL サブモジュールをinit-repository
ダウンロードします。SmartGit は、この段階からのみうまく機能します (以下のコメントを参照)。
Qt のダウンロードが完了すると、次のコマンドでビルド環境が準備されます ([32|64] VS Native Tools コマンド プロンプトを使用して実行する必要もあります)。
configure -developer-build -opensource -confirm-license -mp -nomake examples -nomake tests -debug-and-release -c++11 -no-warnings-are-errors -platform win32-msvc2012
.
このコマンド ラインに関する注意: このc++11
オプションは VS2012 コンパイラでは必要ないかもしれませんが、VS2013 では機能します。これ-no-warnings-are-errors
は、ANGLE の 64 ビット自動ビルドでエラーが発生した場合に必要です。-platform
は自動的に に設定されるwin32-msvc2012
ため、デフォルトでは Qt の 32 ビット ビルドが使用され、おそらくコマンド ラインで -platform を指定する必要はありません (以前のバージョンの VS がインストールされている場合でも)。VS2013 の場合は、 を使用します-platform win32-msvc2013
。
このステップの実行には数分かかりますが、それほど悪くはありません。
最後に、システム上で実際に Qt をビルドするコマンド (VS ネイティブ ツールのコマンド プロンプト内でも実行されます) は次のとおりです。
nmake
ビルドが完了するまで何時間も待つ必要があります。 で出力フォルダーを指定した場合-prefix
(以下の注を参照)、 を使用nmake install
します。それ以外の場合は、それだけです。
ノート:
一般的注意事項
上記のリンクのドキュメントと混同している場合は、参考までに、OpenGL の代わりに (デフォルトで) ANGLE ライブラリが使用されるため、上記の DirectX 11 をインストールする必要がありました。
VS Native Tools コマンド プロンプトを使用して、上記のリンクからすべてのコマンドを実行してください (つまり、、、perl .\init-repository --no-webkit
およびconfigure
) nmake
。Qt を 32 ビットまたは 64 ビットのどちらでビルドするかに応じて、[32|64] ビット コマンド プロンプト (x86
または) を使用します。x64
コマンド プロンプトを開いた状態で perl をインストールした場合 (ファイルが にあることを確認してPATH
ください)、perl がコマンドとして認識されるようにするには、コマンド プロンプトを再起動する必要があります。
「init-repository」を実行する場合 (上記のリンクの手順から)、ドキュメントからは明らかではありませんが、これをperl
;経由で実行する必要があります。すなわちperl ./init-repository --no-webkit
。ただし、 コマンドと コマンドは直接呼び出されconfigure
ます。nmake
に渡す非常に便利なオプションの 1 つconfigure
は です-mp
。これにより、Qt が複数のコアで並行してビルドされ、(長い) ビルド時間が大幅に短縮されます。
-prefix [outfolder]
出力フォルダーを指定するには、コマンドに を追加しますconfigure
。たとえば-prefix %CD%\output\x64\vc12
、64 ビットの Visual Studio 2013 (12.0) ビルドに適した出力 (サブ) フォルダーを使用します。
Unicode サポート (ICU)
Unicode サポートが必要な場合 ( ICU経由))、上記のリンク内に記載されている指示に特に注意してください。要約すると、Windows 用にビルド済みの ICU バイナリは VS 2010 用のみであるため、ICU は VS 2012 で最初からビルドする必要があります。VS 2012 でビルドするのは簡単です。 \allinone、およびデバッグ モードとリリース モードの両方でビルドします (Qt をビルドしているモードに応じて、32 ビット モードまたは 64 ビット モードでビルドします。ICU は出力フォルダーをバイナリ)。(Qt ビルド プロセスは、ICU のデバッグ ビルドとリリース ビルドを適切に見つけます。) エラーなしでビルドする必要があります。次に、<icuroot>\lib へのパスを、"LIB" という (おそらく) 新しい Windows 環境変数の文字列エントリとして追加します (これには Rapid EE を使用できます。LIB を "展開可能な文字列" にします)。エントリが 1 つしかない場合でも RapidEE で)、<icuroot>\include へのパスを (おそらく) 新しい Windows 環境変数 "INCLUDE" に文字列エントリとして追加します。(注: これらのパスを PATH 変数に追加しても機能しません。) Qt のビルド後、追加したこれらのエントリをすべて削除できます。また、するICU dll のランタイム パス (<icuroot>\bin) を環境の PATH 変数に追加しないと、Qt ビルド プロセス (具体的には、uic.exe
実行時)で誤解を招くエラーが発生します。最後に、configure
コマンド ライン (下記) で、必ず-icu
追加のコマンド ライン パラメータとして追加してください。
ICU 障害:
現在、VS2012 コンパイラを使用して Qt5 をビルドすると、ICU が有効になっているときにバグが発生するようです。具体的には、qtbase\src\corelib\codecs\qtextcodec.cpp
Line 688 (Qt5 v5.02) がコーデック名「US-ASCII」(コーデックが NULL) のコーデックを返せず、後でコーデックを逆参照しようとすると「lrelease.exe」がクラッシュします (追跡できなくなりました)。そのファイル/行番号の、しかしそれは明らかに NULLcodec
変数の逆参照です)。残念ながら、これは私の知る限り、WebKit は ICU を必要とするため、VS2012 コンパイラを使用した Qt5 の (少なくとも) 32 ビット ビルドではビルドできないことを意味します。
ICU を有効にした VS2012 コンパイラで Qt5 をビルドできる人がいる場合は、この Wiki を更新してください。
ICUの説明:
パスに ICU がある場合、Qt は自動的にそれをビルドします。つまり、フラグ " -icu
" は暗黙的に存在します。ただし、これにより、前述の「lrelease.exe」でエラーが発生します。したがって、これを回避するには、configure コマンドにフラグ -no-icu を追加します。
追加のサブモジュール
デフォルトのサブモジュールに加えてサブモジュールが必要な場合は、コマンドの完了後にSmartGit (またはコマンド ライン) を使用できますinit-repository
。コマンド ラインにパスをコピーする必要がなく、ユーザー インターフェイスを直接使用できるため、おそらく SmartGit が最も簡単です。
警告:オプションのサブモジュールをダウンロードqlalr
しないでください。Qt ビルド全体と組み合わせてビルドすることはなく、Qt のユーザーには必要ありませんが、Qt の内部開発にのみ使用されます。
警告:シェル コマンド ラインの後に をperl .\init-repository --no-webkit
使用する必要があります (SmartGit ではありません)。これらの手順では、デフォルトの Qt サブモジュールのみが適切にダウンロードされます。SmartGitは現在、サブモジュールを適切に処理しないため、 SmartGit を使用して Git ファイルを複製およびダウンロードしないでください。git://gitorious.org/qt/qt5.git
代わりに、標準の Windows シェル コマンド プロンプトを開き (必ずしも VS Tools のコマンド プロンプトではなく、コマンド プロンプト アプリケーションを使用します)、(Git がシステムに適切にインストールされていると仮定します。SmartGit のインストールでは、これが自動的に行われる場合と行われない場合があります。ない場合は、Git for Windowsに移動して直接インストールします)git clone git://gitorious.org/qt/qt5.git
コマンド ラインから直接入力します。おそらくそれに続くgit checkout stable
(このブランチがデフォルトでチェックアウトされているかどうかはわかりません); 次に、コマンド ラインperl .\init-repository --no-webkit
を使用して DEFAULT リポジトリをプルダウンします (ICU を必要とする WebKit を除き、ICU は VS2012 を使用する 32 ビット Qt5 ではビルドできないようです。コメントを参照してください)。
したがって、必要なすべての Qt ソース ファイルをダウンロードする手順は次のとおりです。 1. Windows コマンド ラインを使用して最初のgit clone git://gitorious.org/qt/qt5.git
. 2. perl .\init-repository --no-webkit
VS Tools 2012 コマンド プロンプト内から実行します。オプションで 3. SmartGit (上記のリンクから) (または同等のもの) を使用して「既存のプロジェクトを開き」(Qt5 ルート フォルダーを選択)、SmartGit 内からプルを実行して、既定以外のリポジトリをダウンロードします (ただし、ダウンロードはしませんqlalr
) 。 . それでおしまい; システムに必要なすべての Qt ファイルとオプションの Qt ファイル (サブモジュールを含む) があります。
ビルドに失敗した、および/または内部使用のみ (および ) である他のオプションのサブモジュールを誰かが発見した場合は、qlalr
この Wiki を更新してそれらを指定してください。
一般に、経由で取得したデフォルトのサブモジュールperl .\init-repository --no-webkit
で十分です。他の (デフォルト以外の) モジュールを知っている場合、または後で見つけた場合は、後でいつでも追加できます。
一般的な問題
ある時点で、コマンド「python」(または類似のもの) が認識されないというエラーが表示された場合は、python.exe
(または適切な.exe
) を含むフォルダーがパス変数の一部であることを確認してください。そうでない場合は、それを追加して (便宜上、前述の RapidEE を使用してください)、実行していたことをもう一度試してください。そこにある場合は、コマンドをパスに追加した後にコマンドプロンプトを再起動したことを確認してください。
他の 2 つのパス関連の問題に注意することが重要です(上記のリンクに関連するドキュメントから引用): および " sh.exe が PATH にある場合、ビルドできない可能性があります (たとえば、git または msys のインストールが原因です)。このようなエラーは、qt5-srcqtbasebinqmake.exe: command not found などで示されます。この場合、 、sh.exe がパスにないことを確認してください。インストールが既に構成されている場合は、再構成する必要があります。」
プロセス中に、ファイルを使用してエラーが発生する場合がありnmake
ます。その場合は、そのディレクトリに移動して、問題のファイルを強制的にビルドしてください。その後nmake
、Qt5 でプロセスを再開します。
特定の問題
警告: Qtプロセス中 (および安全のために、このプロセス全体を通して)ウイルス対策ソフトウェアとサンドボックスを無効にする必要がある場合があります。nmake
内部的に、Qt はウイルス対策プログラムが干渉する可能性のある多くの実行可能ファイルを (場合によってはサイレントに) 実行します。特に、サンドボックス ソフトウェアを使用している場合は、必ずサンドボックスを無効にしてください。
警告: アバスト! サンドボックス ユーザー: アバスト サンドボックスにはバグがあり、アバストの自動サンドボックスを無効にしてもサンドボックスはオフにならず、rcc
Qt のビルド プロセス中に Qt のプログラムによって自動的に作成されたすべてのリソース ファイルがサイレントにサンドボックス化されます。アバストの自動サンドボックス機能をインストールしているユーザーは、自動サンドボックスがオフになっていても、Qt ビルドは常に失敗します。この問題を解決する唯一の方法は、AVAST を完全にアンインストールすることです! Qt をビルドする前にシステムから。アバストを再インストールできます!Qtビルドが完了した後。
Qt5 のコンパイルには長い時間がかかる場合があります (-mp マルチスレッド オプションを使用しても数時間)。忍耐。
ステップ 3: Qt5 と Visual Studio 2012 の統合
Visual Studio Qt5 アドインをダウンロードしてインストールします。ページの下部にある「その他のダウンロード」セクションにあり、Visual Studio Express では動作しません。
Visual Studio 2012 を開き、Qt Options
(トップ メニュー バーの「Qt5」の下にあります) に移動します。
[Qt バージョン] タブで、Qt5 が既に存在するかどうかを確認します。そうでない場合は、[追加] をクリックし、バージョン名 (おそらく 5.xx などの名前) を選択して、qmake.exe
(通常はC:\Qt\qt5\qtbase
) を含むフォルダーに移動します。
Qt オプション ダイアログを終了します。
新しい Visual Studio プロジェクトを作成します。[新しいプロジェクト] ダイアログが表示されると、[Qt5 Projects
テンプレート] オプションが表示されます。
新しい Qt プロジェクトを作成したら、それを右クリックして [QMake で生成されたプロジェクトに変換] を選択します。プロジェクトをビルドし、もう一度右クリックして、[プロジェクトを Qt アドイン プロジェクトに変換] を選択します。再度ビルドしてから実行します。これで Qt プロジェクトが動作するはずです。
Qt5 を既存の Visual Studio 2012 VC++ プロジェクトに追加する
このセクションは、うまくいく場合とうまくいかない場合があります。問題が発生した場合、または追加/より良い解決策がある場合は、コメントを残すか、適切な手順を編集してください。
VS でプロジェクトを右クリックし、[プロジェクトのアンロード] を選択します。再度プロジェクトを右クリックし、「[プロジェクト名].vcxproj の編集」を選択します。これによりプロジェクト ファイルが開き、Qt5 を追加できるようになります。
<Keyword>
Global PropertyGroup に移動し、 Qt4VSv1.0 に追加または変更します。
プロジェクトをリロードし、右クリックして [プロジェクトを Qt アドイン プロジェクトに変換] を選択します。
変換が完了するのを待ち (数秒以上かかることはありません)、 を選択しますQt5>Project Settings
。[モジュール] タブに移動し、プロジェクトが依存するモジュールを確認します (基本的なものは、、、Core
およびWidgets
ですGUI
)。
ここの手順に従って、ディレクトリを追加します$(QTDIR)\include
。
ノート:
を含める場合はいつでも、との競合を防ぐために、そうする前にwindows.h
行う必要があります。#define NOMINMAX
qdatetime.h
上記の手順が完了したら、 を選択して、プロジェクトを Qt Creator で使用できるようにすることができますQt5>Create basic .pro file
。
エンディング ノート:このガイドに含まれる情報に関連する質問がある場合は、新しい質問として投稿してください (ここでは回答ではありません)。回答または回答へのリンクが追加される場合があります。