2017-03-15 20:24:05 -04:00
#Build Guide For Visual Studio 2015 or Qt Creator
2016-03-03 21:55:49 -05:00
##Tools
###git
2016-01-04 08:45:40 -05:00
2016-03-01 20:58:34 -05:00
Install [git ](https://git-scm.com/downloads ).
2016-01-04 08:45:40 -05:00
2016-03-03 21:55:49 -05:00
###Visual Studio
2017-03-15 20:24:05 -04:00
Install [Microsoft Visual Studio 2015 or later ](https://www.visualstudio.com/en-us/downloads/download-visual-studio-vs.aspx ), then install the latest updates.
2016-01-04 08:45:40 -05:00
2016-03-03 21:55:49 -05:00
###Qt
2017-03-15 20:32:26 -04:00
Install Qt for Windows 64-bit (VS 2015) 5.8 or later (http://www.qt.io/download/).
2016-03-03 21:55:49 -05:00
2016-03-03 22:32:30 -05:00
Add system environment variable named `QTPATH` and point it to the location of the Qt folder. On a default install, this will be something like:
2016-03-03 21:55:49 -05:00
2017-03-15 20:24:05 -04:00
`C:\Qt\5.8\msvc2015_64`
2016-01-04 08:45:40 -05:00
2016-03-03 21:55:49 -05:00
###Wix
2016-03-03 23:24:45 -05:00
2016-03-03 21:55:49 -05:00
To build the installer, you must have Wix installed. If you are unconcerned with it, you can skip this step and just dismiss the warning that shows when opening the solution later. It's recommended you ignore the installer since official builds are provided on this page.
##Obtaining source
###This project
2016-03-03 23:24:45 -05:00
2016-03-03 21:55:49 -05:00
Open up the Visual Studio x64 Native Tools Command Prompt.
2016-01-04 08:45:40 -05:00
2016-03-01 20:58:34 -05:00
Create a new folder in your development area named fractorium:
2016-01-04 08:45:40 -05:00
2016-03-01 20:58:34 -05:00
`mkdir fractorium`
`cd fractorium`
2016-05-30 17:51:54 -04:00
`git clone https://mfeemster@bitbucket.org/mfeemster/fractorium.git`
2016-01-04 08:45:40 -05:00
2016-03-03 21:55:49 -05:00
###Prerequisites
2016-03-03 23:24:45 -05:00
2016-03-01 20:58:34 -05:00
There are six prerequisite dependencies. Two of them must be downloaded manually:
[libjpeg ](http://www.ijg.org/ )
2016-01-04 08:45:40 -05:00
2016-03-03 21:55:49 -05:00
[tbb ](https://www.threadingbuildingblocks.org/download ) (Intel provides executable only releases in addition to open source releases. You must get the open source release)
2016-01-04 08:45:40 -05:00
2016-03-01 20:47:59 -05:00
Extract them into the folder you created such that they are arranged like so:
2016-01-04 08:45:40 -05:00
2016-03-01 20:47:59 -05:00
```
[fractorium]
│
├─libjpeg
├─tbb
```
2016-01-04 08:45:40 -05:00
2016-03-01 20:58:34 -05:00
Go into the fractorium folder and run this script which will get the rest of the prerequisites from git and build them:
2016-01-04 08:45:40 -05:00
2016-03-01 21:10:37 -05:00
`cd fractorium`
`makedeps.bat`
2016-01-04 08:45:40 -05:00
2017-07-23 01:33:16 -04:00
This will download and build `glm libopenexr libpng libxml zlib` . You will have a folder structure like this:
2016-01-04 08:45:40 -05:00
```
2016-03-03 21:55:49 -05:00
[fractorium]
2016-01-04 08:45:40 -05:00
│
2016-03-01 20:47:59 -05:00
├─glm
├─libjpeg
├─libpng
├─libxml2
2017-07-23 01:33:16 -04:00
├─openexr
2016-03-01 20:47:59 -05:00
├─tbb
2016-01-04 08:45:40 -05:00
└─fractorium
2016-03-01 21:10:37 -05:00
│
2016-03-01 20:58:34 -05:00
├─Deps
│
2017-07-23 01:35:35 -04:00
├─Include
│
├─OpenEXR
│
├─*.h
│
2016-03-01 20:58:34 -05:00
├─libjpeg.lib
├─libpng.lib
├─libxml2.lib
├─libxml2.dll
├─tbb.dll
├─tbb.lib
├─zlib.lib
2017-07-23 01:33:16 -04:00
├─Half.lib
├─Iex.lib
├─IexMath.lib
├─IlmImf.lib
├─IlmImfUtil.lib
├─IlmThread.lib
├─Imath.lib
├─Half.dll
├─Iex-2_2.dll
├─IexMath-2_2.dll
├─IlmImf-2_2.dll
├─IlmImfUtil-2_2.dll
├─IlmThread-2_2.dll
├─Imath-2_2.dll
2016-01-04 08:45:40 -05:00
```
2016-03-03 21:55:49 -05:00
##Building with Qt Creator or Visual Studio
2016-03-03 23:24:45 -05:00
###Begin build with Qt Creator
2017-03-15 20:24:05 -04:00
Open the Qt Project `fractorium/main.pro` using Qt Creator with the default config of *Desktop Qt [version] MSVC2015 64bit* .
2016-03-09 22:55:24 -05:00
Make sure *Shadow build* in *Edit build configuration* for both *Debug* and *Release* is unchecked.
2016-03-03 23:24:45 -05:00
Switch to the *Release* configuration.
Under *Build Steps* , add an additional argument of `install` to the `make` command to force all dependencies to be copied to the output folder. The final make command should look like:
2016-03-09 22:55:24 -05:00
`jom.exe install in /path/to/fractorium`
2016-01-04 08:45:40 -05:00
2016-03-03 23:24:45 -05:00
Ensure all projects are in the *Release* configuration and build main.pro.
2016-01-04 08:45:40 -05:00
2016-03-01 21:24:21 -05:00
The outputs will be placed in `fractorium/Bin/release` several minutes later if no error occurs.
2016-01-04 08:45:40 -05:00
2016-03-03 23:24:45 -05:00
###Begin build with Visual Studio
2016-03-03 21:55:49 -05:00
####Visual Studio Qt Addon
Install the [Visual Studio Qt Addon ](http://www.qt.io/download/ ).
2016-03-03 22:00:18 -05:00
Run Visual Studio and verify there is a menu item named *Qt5* . Click on it and click *Qt Options* .
2016-03-03 21:55:49 -05:00
2017-03-15 20:24:05 -04:00
Add a new Qt version to the list with the exact name of "Qt5", and set its path to the same as `$QTPATH` , which will be something like:
2016-03-03 21:55:49 -05:00
2017-03-15 20:24:05 -04:00
`C:\Qt\5.8\msvc2015_64`
2016-03-03 21:55:49 -05:00
2017-03-15 20:24:05 -04:00
The name "Qt5" must match exactly and this step must be completed before the Fractorium solution is opened. If not, the Qt add-in will completely ruin all solution and project files that use Qt.
2016-03-03 21:55:49 -05:00
2016-03-03 22:00:18 -05:00
Set the default version to the newly created Qt version and click *Ok* .
2016-03-03 21:55:49 -05:00
2017-03-15 20:24:05 -04:00
Open the file Fractorium.sln under Builds/MSVC/2015
2016-03-01 21:00:02 -05:00
Set the configuration to release, and build all.
2016-03-03 21:55:49 -05:00
###Outputs
2016-03-03 22:45:27 -05:00
The outputs will be the same whether Visual Studio or Qt Creator was used, however their locations will be different.
Qt Creator will place its outputs in:
`fractorium/Bin/Release`
and Visual Studio will place its outputs in:
2016-03-01 21:00:02 -05:00
2016-03-01 21:24:21 -05:00
`fractorium/Bin/x64/Release`
2016-03-01 21:00:02 -05:00
2016-03-03 23:24:45 -05:00
The output contents will be:
2016-03-01 21:00:02 -05:00
2016-01-04 08:45:40 -05:00
```
2017-03-15 20:24:05 -04:00
boxtail_pack_02.gradient
boxtail_pack_03_triangle.gradient
boxtail_pack_04_mineshack.gradient
2016-03-03 21:55:49 -05:00
dark.qss
2016-03-09 22:58:00 -05:00
ember.dll
ember.exp
ember.lib
2016-01-04 08:45:40 -05:00
emberanimate.exe
2016-03-09 22:58:41 -05:00
embercl.dll
embercl.exp
embercl.lib
2016-01-04 08:45:40 -05:00
embergenome.exe
emberrender.exe
2017-03-15 20:24:05 -04:00
fardareismai_pack_01_variety_number_128.gradient
fardareismai_pack_02_b_sides.gradient
fardareismai_pack_03_old_and_new.gradient
fardareismai_pack_04_hoard.gradient
2016-03-03 21:55:49 -05:00
flam3-palettes.xml
2017-03-15 20:24:05 -04:00
fractaldesire_pack_01.gradient
2016-01-04 08:45:40 -05:00
fractorium.exe
2017-07-23 01:33:16 -04:00
half.dll
iex-2_2.dll
iexmath-2_2.dll
ilmimf-2_2.dll
ilmthread-2_2.dll
imath-2_2.dll
2016-03-03 21:55:49 -05:00
libxml2.dll
2016-03-03 22:43:31 -05:00
Qt5Core.dll
Qt5Gui.dll
Qt5Widgets.dll
2017-03-15 20:24:05 -04:00
rce_ordinary_pack_01_colornation.gradient
tatasz_pack_01.gradient
tatasz_pack_02_colder.gradient
tatasz_pack_02_dark.gradient
tatasz_pack_02_warmer.gradient
tatasz_pack_03.gradient
2016-03-03 21:55:49 -05:00
tbb.dll
2016-03-03 22:43:31 -05:00
platforms\qwindows.dll
2016-01-04 08:45:40 -05:00
```
2016-03-01 21:24:21 -05:00
Double click fractorium.exe to run it, and use the command line to run the others.
2016-03-01 20:47:59 -05:00
2017-03-15 20:24:05 -04:00
To run on a computer without Visual Studio 2015, these files also need to be in the folder:
2016-01-04 08:45:40 -05:00
```
2017-03-15 20:24:05 -04:00
MSVC2015\VC\redist\x64\Microsoft.VC140.CRT\msvcp140.dll
MSVC2015\VC\redist\x64\Microsoft.VC140.CRT\vcruntime140.dll
MSVC2015\VC\redist\x64\Microsoft.VC140.CRT\vccorlib140.dll
MSVC2015\VC\redist\x64\Microsoft.VC140.CRT\concrt140.dll
2016-01-04 08:45:40 -05:00
```
2017-03-15 20:24:05 -04:00
or you can install [Visual C++ Redistributable Packages for Visual Studio 2015 (64 bit) ](https://www.microsoft.com/en-us/download/details.aspx?id=53840 )
2016-01-04 08:45:40 -05:00
2016-03-01 21:10:37 -05:00
##Final file structure for distribution
2016-01-04 08:45:40 -05:00
```
[YOUR FOLDER]
2017-03-15 20:24:05 -04:00
│
├─ boxtail_pack_02.gradient
├─ boxtail_pack_03_triangle.gradient
├─ boxtail_pack_04_mineshack.gradient
├─ dark.qss
├─ ember.dll
├─ emberanimate.exe
├─ embercl.dll
├─ embergenome.exe
├─ emberrender.exe
├─ fardareismai_pack_01_variety_number_128.gradient
├─ fardareismai_pack_02_b_sides.gradient
├─ fardareismai_pack_03_old_and_new.gradient
├─ fardareismai_pack_04_hoard.gradient
├─ flam3-palettes.xml
├─ fractaldesire_pack_01.gradient
├─ fractorium.exe
2017-07-23 01:33:16 -04:00
├─ half.dll
├─ iex-2_2.dll
├─ iexmath-2_2.dll
├─ ilmimf-2_2.dll
├─ ilmthread-2_2.dll
├─ imath-2_2.dll
2017-03-15 20:24:05 -04:00
├─ libxml2.dll
├─ Qt5Core.dll
├─ Qt5Gui.dll
├─ Qt5Widgets.dll
├─ rce_ordinary_pack_01_colornation.gradient
├─ tatasz_pack_01.gradient
├─ tatasz_pack_02_colder.gradient
├─ tatasz_pack_02_dark.gradient
├─ tatasz_pack_02_warmer.gradient
├─ tatasz_pack_03.gradient
├─ tbb.dll
│
├─ msvcp140.dll (optional)
├─ vcruntime140.dll (optional)
├─ vccorlib140.dll (optional)
├─ concrt140.dll (optional)
│
└─platforms
2016-03-03 21:55:49 -05:00
│
├─qwindows.dll
2016-01-04 08:45:40 -05:00
```