mirror of
https://bitbucket.org/mfeemster/fractorium.git
synced 2025-01-21 21:20:07 -05:00
Manual merge
This commit is contained in:
commit
ccd4ea8d05
@ -16,7 +16,7 @@ INSTALLS += target
|
|||||||
QMAKE_CXXFLAGS += -D_USRDLL
|
QMAKE_CXXFLAGS += -D_USRDLL
|
||||||
QMAKE_CXXFLAGS += -D_CONSOLE
|
QMAKE_CXXFLAGS += -D_CONSOLE
|
||||||
QMAKE_CXXFLAGS += -BUILDING_EMBER
|
QMAKE_CXXFLAGS += -BUILDING_EMBER
|
||||||
|
win32: DEFINES += BUILDING_EMBER
|
||||||
SOURCES += \
|
SOURCES += \
|
||||||
$$PRJ_DIR/Affine2D.cpp \
|
$$PRJ_DIR/Affine2D.cpp \
|
||||||
$$PRJ_DIR/DllMain.cpp \
|
$$PRJ_DIR/DllMain.cpp \
|
||||||
|
@ -18,6 +18,7 @@ LIBS += -L$$absolute_path($$DESTDIR) -lEmber
|
|||||||
QMAKE_CXXFLAGS += -D_USRDLL
|
QMAKE_CXXFLAGS += -D_USRDLL
|
||||||
QMAKE_CXXFLAGS += -D_CONSOLE
|
QMAKE_CXXFLAGS += -D_CONSOLE
|
||||||
QMAKE_CXXFLAGS += -BUILDING_EMBERCL
|
QMAKE_CXXFLAGS += -BUILDING_EMBERCL
|
||||||
|
win32: DEFINES += BUILDING_EMBERCL
|
||||||
|
|
||||||
SOURCES += \
|
SOURCES += \
|
||||||
$$PRJ_DIR/DEOpenCLKernelCreator.cpp \
|
$$PRJ_DIR/DEOpenCLKernelCreator.cpp \
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
VERSION = 0.9.9.2
|
VERSION = 0.9.9.2
|
||||||
|
win32:CONFIG += skip_target_version_ext
|
||||||
message(PWD: $$(PWD))
|
message(PWD: $$(PWD))
|
||||||
|
|
||||||
# TODO: win32 install dirs?
|
# TODO: win32 install dirs?
|
||||||
@ -15,12 +15,27 @@ unix|macx {
|
|||||||
#EMBER_ROOT = $$(PWD)/../../..
|
#EMBER_ROOT = $$(PWD)/../../..
|
||||||
#It must be this...
|
#It must be this...
|
||||||
EMBER_ROOT = ./../../../
|
EMBER_ROOT = ./../../../
|
||||||
|
|
||||||
# When compiling from project root
|
# When compiling from project root
|
||||||
autobuild {
|
autobuild {
|
||||||
EMBER_ROOT = $$(PWD)/../..
|
EMBER_ROOT = $$(PWD)/../..
|
||||||
}
|
}
|
||||||
|
|
||||||
|
win32:{
|
||||||
|
EMBER_ROOT = $$(PWD)../../..
|
||||||
|
EXTERNAL_DIR = $$(PWD)../../../../External
|
||||||
|
EXTERNAL_LIB = $$(PWD)../../../External/libs
|
||||||
|
# EXTERNAL_DIR which contains Third Party Codes is in the parent folder of "fractorium"
|
||||||
|
# EXTERNAL_LIB is in EXTERNAL_DIR actually, but it is strange that EXTERNAL_DIR must go
|
||||||
|
# one more step upper than EXTERNAL_LIB to get it work
|
||||||
|
LIB_INSTALL_DIR = $$(PWD)../../../Install/lib
|
||||||
|
BIN_INSTALL_DIR = $$(PWD)../../../Install/bin
|
||||||
|
SHARE_INSTALL_DIR = $$(PWD)../../../Install/share/fractorium
|
||||||
|
# INSTALL_DIRs Don't work?
|
||||||
|
message(EMBER_ROOT: $$absolute_path($$EMBER_ROOT))
|
||||||
|
message(EXTERNAL: $$absolute_path($$EXTERNAL_DIR))
|
||||||
|
message(EXTERNAL_LIB:$$absolute_path($$EXTERNAL_LIB) )
|
||||||
|
}
|
||||||
|
|
||||||
message(EMBER_ROOT: $$EMBER_ROOT)
|
message(EMBER_ROOT: $$EMBER_ROOT)
|
||||||
|
|
||||||
SRC_DIR = $$EMBER_ROOT/Source
|
SRC_DIR = $$EMBER_ROOT/Source
|
||||||
@ -29,13 +44,19 @@ ASSETS_DIR = $$EMBER_ROOT/Data
|
|||||||
LOCAL_LIB_DIR = $$(PWD)/../../lib
|
LOCAL_LIB_DIR = $$(PWD)/../../lib
|
||||||
LOCAL_INCLUDE_DIR = $$(PWD)/../../include
|
LOCAL_INCLUDE_DIR = $$(PWD)/../../include
|
||||||
|
|
||||||
|
win32:{
|
||||||
|
LOCAL_LIB_DIR = $$(PWD)../../lib
|
||||||
|
LOCAL_INCLUDE_DIR = $$(PWD)../../include
|
||||||
|
}
|
||||||
CONFIG(release, debug|release) {
|
CONFIG(release, debug|release) {
|
||||||
CONFIG += warn_off
|
CONFIG += warn_off
|
||||||
DESTDIR = $$EMBER_ROOT/Bin/release
|
DESTDIR = $$EMBER_ROOT/Bin/release
|
||||||
|
win32:DESTDIR = $$(PWD)../../../Bin/release
|
||||||
}
|
}
|
||||||
|
|
||||||
CONFIG(debug, debug|release) {
|
CONFIG(debug, debug|release) {
|
||||||
DESTDIR = $$EMBER_ROOT/Bin/debug
|
DESTDIR = $$EMBER_ROOT/Bin/debug
|
||||||
|
win32:DESTDIR = $$(PWD)../../../Bin/debug
|
||||||
}
|
}
|
||||||
|
|
||||||
macx {
|
macx {
|
||||||
@ -54,7 +75,7 @@ macx {
|
|||||||
QMAKE_CXXFLAGS += -stdlib=libc++
|
QMAKE_CXXFLAGS += -stdlib=libc++
|
||||||
}
|
}
|
||||||
|
|
||||||
!macx {
|
!macx:!win32 {
|
||||||
CONFIG += precompile_header
|
CONFIG += precompile_header
|
||||||
|
|
||||||
LIBS += -L/usr/lib/x86_64-linux-gnu -L$$LOCAL_LIB_DIR -lGL
|
LIBS += -L/usr/lib/x86_64-linux-gnu -L$$LOCAL_LIB_DIR -lGL
|
||||||
@ -62,25 +83,35 @@ macx {
|
|||||||
|
|
||||||
QMAKE_LFLAGS_RELEASE += -s
|
QMAKE_LFLAGS_RELEASE += -s
|
||||||
}
|
}
|
||||||
|
# Win32: put "GlU32.Lib" "WS2_32.Lib" "OpenGL32.Lib" under "MSVC2013\Windows Kits\8.1\Lib\winv6.3\um\x64\" ,
|
||||||
|
# and "CUDA\v7.5\lib\x64\OpenCL.lib" into $$EXTERNAL_LIB
|
||||||
|
win32 {
|
||||||
|
|
||||||
native {
|
LIBS +=$$absolute_path($$EXTERNAL_LIB)/GlU32.Lib
|
||||||
QMAKE_CXXFLAGS += -march=native
|
LIBS +=$$absolute_path($$EXTERNAL_LIB)/OpenGL32.lib
|
||||||
} else {
|
LIBS +=$$absolute_path($$EXTERNAL_LIB)/WS2_32.lib
|
||||||
QMAKE_CXXFLAGS += -march=k8
|
LIBS +=$$absolute_path($$EXTERNAL_LIB)/OpenCL.lib
|
||||||
|
}
|
||||||
|
!win32 {
|
||||||
|
native {
|
||||||
|
QMAKE_CXXFLAGS += -march=native
|
||||||
|
} else {
|
||||||
|
QMAKE_CXXFLAGS += -march=k8
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
OBJECTS_DIR = $$PWD/.obj
|
OBJECTS_DIR = $$PWD/.obj
|
||||||
MOC_DIR = $$PWD/.moc
|
MOC_DIR = $$PWD/.moc
|
||||||
RCC_DIR = $$PWD/.qrc
|
RCC_DIR = $$PWD/.qrc
|
||||||
UI_DIR = $$PWD/.ui
|
UI_DIR = $$PWD/.ui
|
||||||
|
!win32 {
|
||||||
|
LIBS += -L/usr/lib -ljpeg
|
||||||
|
LIBS += -L/usr/lib -lpng
|
||||||
|
LIBS += -L/usr/lib -ltbb
|
||||||
|
LIBS += -L/usr/lib -lpthread
|
||||||
|
LIBS += -L/usr/lib/x86_64-linux-gnu -lxml2
|
||||||
|
|
||||||
LIBS += -L/usr/lib -ljpeg
|
CMAKE_CXXFLAGS += -DCL_USE_DEPRECATED_OPENCL_1_1_APIS
|
||||||
LIBS += -L/usr/lib -lpng
|
|
||||||
LIBS += -L/usr/lib -ltbb
|
|
||||||
LIBS += -L/usr/lib -lpthread
|
|
||||||
LIBS += -L/usr/lib/x86_64-linux-gnu -lxml2
|
|
||||||
|
|
||||||
CMAKE_CXXFLAGS += -DCL_USE_DEPRECATED_OPENCL_1_1_APIS
|
|
||||||
|
|
||||||
# NOTE: last path will be the first to search. gcc -I and -L appends to the
|
# NOTE: last path will be the first to search. gcc -I and -L appends to the
|
||||||
# beginning of the path list.
|
# beginning of the path list.
|
||||||
@ -88,52 +119,69 @@ CMAKE_CXXFLAGS += -DCL_USE_DEPRECATED_OPENCL_1_1_APIS
|
|||||||
# NOTE: qmake will resolve symlinks. If /usr/local/include/CL is a symlink to
|
# NOTE: qmake will resolve symlinks. If /usr/local/include/CL is a symlink to
|
||||||
# /usr/include/nvidia-352/CL, qmake will generate Makefiles using the latter.
|
# /usr/include/nvidia-352/CL, qmake will generate Makefiles using the latter.
|
||||||
|
|
||||||
INCLUDEPATH += /usr/include
|
INCLUDEPATH += /usr/include
|
||||||
INCLUDEPATH += /usr/local/include
|
INCLUDEPATH += /usr/local/include
|
||||||
|
}
|
||||||
|
|
||||||
INCLUDEPATH += $$LOCAL_INCLUDE_DIR/vendor
|
INCLUDEPATH += $$LOCAL_INCLUDE_DIR/vendor
|
||||||
INCLUDEPATH += $$LOCAL_INCLUDE_DIR
|
INCLUDEPATH += $$LOCAL_INCLUDE_DIR
|
||||||
|
|
||||||
# Using a local version of opencl-headers, to make sure version 1.2.
|
# Using a local version of opencl-headers, to make sure version 1.2.
|
||||||
#INCLUDEPATH += /usr/include/CL
|
#INCLUDEPATH += /usr/include/CL
|
||||||
#INCLUDEPATH += /usr/local/include/CL
|
#INCLUDEPATH += /usr/local/include/CL
|
||||||
|
!win32 {
|
||||||
|
INCLUDEPATH += /usr/include/GL
|
||||||
|
INCLUDEPATH += /usr/local/include/GL
|
||||||
|
|
||||||
INCLUDEPATH += /usr/include/GL
|
INCLUDEPATH += /usr/include/glm
|
||||||
INCLUDEPATH += /usr/local/include/GL
|
INCLUDEPATH += /usr/include/tbb
|
||||||
|
INCLUDEPATH += /usr/include/libxml2
|
||||||
INCLUDEPATH += /usr/include/glm
|
}
|
||||||
INCLUDEPATH += /usr/include/tbb
|
win32 {
|
||||||
INCLUDEPATH += /usr/include/libxml2
|
INCLUDEPATH += $$EXTERNAL_DIR/glm
|
||||||
|
INCLUDEPATH += $$EXTERNAL_DIR/tbb/include
|
||||||
|
INCLUDEPATH += $$EXTERNAL_DIR/libjpeg
|
||||||
|
INCLUDEPATH += $$EXTERNAL_DIR/libpng
|
||||||
|
INCLUDEPATH += $$EXTERNAL_DIR/libxml2/include
|
||||||
|
LIBS += $$absolute_path($$EXTERNAL_LIB)/libjpeg.lib
|
||||||
|
LIBS += $$absolute_path($$EXTERNAL_LIB)/libpng.lib /NODEFAULTLIB:LIBCMT
|
||||||
|
LIBS += $$absolute_path($$EXTERNAL_LIB)/libxml2.lib
|
||||||
|
LIBS += $$absolute_path($$EXTERNAL_LIB)/tbb.lib
|
||||||
|
LIBS += $$absolute_path($$EXTERNAL_LIB)/tbb_debug.lib
|
||||||
|
LIBS += $$absolute_path($$EXTERNAL_LIB)/zlib.lib
|
||||||
|
}
|
||||||
INCLUDEPATH += $$SRC_DIR/Ember
|
INCLUDEPATH += $$SRC_DIR/Ember
|
||||||
INCLUDEPATH += $$SRC_DIR/EmberCL
|
INCLUDEPATH += $$SRC_DIR/EmberCL
|
||||||
INCLUDEPATH += $$SRC_DIR/EmberCommon
|
INCLUDEPATH += $$SRC_DIR/EmberCommon
|
||||||
|
|
||||||
QMAKE_CXXFLAGS_RELEASE += -O2
|
QMAKE_CXXFLAGS_RELEASE += -O2
|
||||||
QMAKE_CXXFLAGS_RELEASE += -DNDEBUG
|
QMAKE_CXXFLAGS_RELEASE += -DNDEBUG
|
||||||
QMAKE_CXXFLAGS_RELEASE += -fomit-frame-pointer
|
!win32 {
|
||||||
|
QMAKE_CXXFLAGS_RELEASE += -fomit-frame-pointer
|
||||||
QMAKE_CXXFLAGS += -fPIC
|
QMAKE_CXXFLAGS += -fPIC
|
||||||
QMAKE_CXXFLAGS += -fpermissive
|
QMAKE_CXXFLAGS += -fpermissive
|
||||||
QMAKE_CXXFLAGS += -pedantic
|
QMAKE_CXXFLAGS += -pedantic
|
||||||
QMAKE_CXXFLAGS += -std=c++11
|
QMAKE_CXXFLAGS += -std=c++11
|
||||||
QMAKE_CXXFLAGS += -Wnon-virtual-dtor
|
QMAKE_CXXFLAGS += -Wnon-virtual-dtor
|
||||||
QMAKE_CXXFLAGS += -Wshadow
|
QMAKE_CXXFLAGS += -Wshadow
|
||||||
QMAKE_CXXFLAGS += -Winit-self
|
QMAKE_CXXFLAGS += -Winit-self
|
||||||
QMAKE_CXXFLAGS += -Wredundant-decls
|
QMAKE_CXXFLAGS += -Wredundant-decls
|
||||||
QMAKE_CXXFLAGS += -Wcast-align
|
QMAKE_CXXFLAGS += -Wcast-align
|
||||||
QMAKE_CXXFLAGS += -Winline
|
QMAKE_CXXFLAGS += -Winline
|
||||||
QMAKE_CXXFLAGS += -Wunreachable-code
|
QMAKE_CXXFLAGS += -Wunreachable-code
|
||||||
QMAKE_CXXFLAGS += -Wmissing-include-dirs
|
QMAKE_CXXFLAGS += -Wmissing-include-dirs
|
||||||
QMAKE_CXXFLAGS += -Wswitch-enum
|
QMAKE_CXXFLAGS += -Wswitch-enum
|
||||||
QMAKE_CXXFLAGS += -Wswitch-default
|
QMAKE_CXXFLAGS += -Wswitch-default
|
||||||
QMAKE_CXXFLAGS += -Wmain
|
QMAKE_CXXFLAGS += -Wmain
|
||||||
QMAKE_CXXFLAGS += -Wzero-as-null-pointer-constant
|
QMAKE_CXXFLAGS += -Wzero-as-null-pointer-constant
|
||||||
QMAKE_CXXFLAGS += -Wfatal-errors
|
QMAKE_CXXFLAGS += -Wfatal-errors
|
||||||
QMAKE_CXXFLAGS += -Wall -fpermissive
|
QMAKE_CXXFLAGS += -Wall -fpermissive
|
||||||
QMAKE_CXXFLAGS += -Wold-style-cast
|
QMAKE_CXXFLAGS += -Wold-style-cast
|
||||||
QMAKE_CXXFLAGS += -Wno-unused-parameter
|
QMAKE_CXXFLAGS += -Wno-unused-parameter
|
||||||
QMAKE_CXXFLAGS += -Wno-unused-function
|
QMAKE_CXXFLAGS += -Wno-unused-function
|
||||||
QMAKE_CXXFLAGS += -Wold-style-cast
|
QMAKE_CXXFLAGS += -Wold-style-cast
|
||||||
|
}
|
||||||
QMAKE_CXXFLAGS += -D_M_X64
|
QMAKE_CXXFLAGS += -D_M_X64
|
||||||
QMAKE_CXXFLAGS += -D_CONSOLE
|
QMAKE_CXXFLAGS += -D_CONSOLE
|
||||||
QMAKE_CXXFLAGS += -D_USRDLL
|
QMAKE_CXXFLAGS += -D_USRDLL
|
||||||
|
win32:QMAKE_CXXFLAGS += -bigobj
|
||||||
|
224
Data/BuildGuideQtCreator.md
Normal file
224
Data/BuildGuideQtCreator.md
Normal file
@ -0,0 +1,224 @@
|
|||||||
|
#Building Guide for Fractorium Using MSVC2013 and Qt Creator (64 bit)
|
||||||
|
##Requirements
|
||||||
|
|
||||||
|
You need to have MSVC2013 compiler and Qt for Windows 64-bit (VS 2013) like Qt 5.5.1 (http://download.qt.io/official_releases/qt/5.5/5.5.1/qt-opensource-windows-x86-msvc2013_64-5.5.1.exe)
|
||||||
|
|
||||||
|
##Prerequisites
|
||||||
|
Download Prerequisites ( /glm /libjpeg /libpng /libxml2 /tbb /zlib ) according to [mfeemster's wiki](https://github.com/mfeemster/fractorium/wiki/Building).
|
||||||
|
Extract them in the parallel folder of `fractorium` named `External`
|
||||||
|
You can refer to the [folder structure](#folder-structure) below
|
||||||
|
Open your `Visual Studio Tools Command Prompt (amd64 2013)` and do the followings in folders below:
|
||||||
|
|
||||||
|
######\External\libjpeg (jpegsr9a.zip)
|
||||||
|
- run in prompt
|
||||||
|
|
||||||
|
```
|
||||||
|
SET Include=%Include%;"C:\Program Files (x86)\Microsoft SDKs\Windows\v7.1A\Include"
|
||||||
|
```
|
||||||
|
|
||||||
|
(to include WIN32.mak)
|
||||||
|
(I use `SET Include=%Include%;"B:\MSVC2013\Windows Kits\v7.1A\Include"`)
|
||||||
|
|
||||||
|
```
|
||||||
|
nmake /f makefile.vc setup-v10
|
||||||
|
nmake nodebug=1 /f makefile.vc clean all
|
||||||
|
```
|
||||||
|
|
||||||
|
copy `libjpeg.lib` in `External\libjpeg` to `External\libs`
|
||||||
|
|
||||||
|
|
||||||
|
###### \External\zlib (zlib128.zip)
|
||||||
|
- run in prompt
|
||||||
|
|
||||||
|
```
|
||||||
|
nmake -f win32/Makefile.msc clean all
|
||||||
|
```
|
||||||
|
|
||||||
|
copy `zlib.lib` in `External\zlib` to `External\libs`
|
||||||
|
|
||||||
|
###### \External\libxml2 (libxml2-2.9.3.zip)
|
||||||
|
- cd to `External\libxml2\win32`
|
||||||
|
|
||||||
|
```
|
||||||
|
cscript configure.js compiler=msvc iconv=no zlib=yes include=..\..\zlib lib=..\..\zlib
|
||||||
|
nmake /f Makefile.msvc clean all
|
||||||
|
```
|
||||||
|
|
||||||
|
copy `libxml2.lib` in `External\libxml2\win32\bin.msvc` to `External\libs`
|
||||||
|
|
||||||
|
###### \External\libpng (lpng1620.zip)
|
||||||
|
- First, copy `zlib.lib` `zlib.h` and `zconf.h` to `External\libpng\zlib` (create this folder if no exsiting)
|
||||||
|
|
||||||
|
```
|
||||||
|
nmake -f scripts\makefile.vcwin32 clean all
|
||||||
|
```
|
||||||
|
|
||||||
|
copy `libpng.lib` in `External\libpng` to `External\libs`
|
||||||
|
|
||||||
|
###### \External\glm (glm-0.9.6.3.zip)
|
||||||
|
- noting to do, make sure you extract it correctly.
|
||||||
|
|
||||||
|
###### \External\tbb (tbb44_20151115oss_win_0.zip)
|
||||||
|
- copy `External\tbb\lib\intel64\vc12\tbb_debug.lib` and `External\tbb\lib\intel64\vc12\tbb.lib` to `External\libs`
|
||||||
|
|
||||||
|
##Collect libs and includes
|
||||||
|
###### \External\libs
|
||||||
|
- copy `GlU32.Lib` `WS2_32.Lib` `OpenGL32.Lib` under `MSVC2013\Windows Kits\8.1\Lib\winv6.3\um\x64`
|
||||||
|
to this folder (`\External\libs`)
|
||||||
|
install CUDA toolkit and copy `CUDA\v7.5\lib\x64\OpenCL.lib` to this folder (`\External\libs`)
|
||||||
|
|
||||||
|
- Now you should already have these files in the folder:
|
||||||
|
|
||||||
|
```
|
||||||
|
GlU32.Lib
|
||||||
|
libjpeg.lib
|
||||||
|
libpng.lib
|
||||||
|
libxml2.lib
|
||||||
|
OpenCL.lib
|
||||||
|
OpenGL32.Lib
|
||||||
|
tbb.lib
|
||||||
|
tbb_debug.lib
|
||||||
|
WS2_32.Lib
|
||||||
|
zlib.lib
|
||||||
|
```
|
||||||
|
|
||||||
|
###### \fractorium\Builds\lib
|
||||||
|
- copy anything(they are `*.h`) under `CUDA\v7.5\include\CL`
|
||||||
|
to this folder `\fractorium\Builds\include\vendor\CL` (overwrite)
|
||||||
|
|
||||||
|
**All Done!**
|
||||||
|
<a id="folder-structure"></a>
|
||||||
|
|
||||||
|
You shuold have folder structure like this:
|
||||||
|
|
||||||
|
```
|
||||||
|
[YOUR ROOT FOLDER]
|
||||||
|
│
|
||||||
|
├─External
|
||||||
|
│ ├─glm
|
||||||
|
│ │ ├─glm
|
||||||
|
│ │ ...
|
||||||
|
│ ├─libjpeg
|
||||||
|
│ ├─libpng
|
||||||
|
│ │ ├─scripts
|
||||||
|
│ │ ├─zlib
|
||||||
|
│ │ ...
|
||||||
|
│ ├─libs
|
||||||
|
│ │ GlU32.Lib
|
||||||
|
│ │ libjpeg.lib
|
||||||
|
│ │ libpng.lib
|
||||||
|
│ │ libxml2.lib
|
||||||
|
│ │ OpenCL.lib
|
||||||
|
│ │ OpenGL32.Lib
|
||||||
|
│ │ tbb.lib
|
||||||
|
│ │ tbb_debug.lib
|
||||||
|
│ │ WS2_32.Lib
|
||||||
|
│ │ zlib.lib
|
||||||
|
│ │
|
||||||
|
│ ├─libxml2
|
||||||
|
│ │ ├─include
|
||||||
|
│ │ │ └─libxml
|
||||||
|
│ │ ...
|
||||||
|
│ ├─tbb
|
||||||
|
│ │ ├─include
|
||||||
|
│ │ │ ├─serial
|
||||||
|
│ │ │ │ └─tbb
|
||||||
|
│ │ │ └─tbb
|
||||||
|
│ │ │ ├─compat
|
||||||
|
│ │ │ ├─internal
|
||||||
|
│ │ │ └─machine
|
||||||
|
│ │ ├─lib
|
||||||
|
│ │ │ ├─ia32
|
||||||
|
│ │ │ │
|
||||||
|
│ │ │ └─intel64
|
||||||
|
│ │ │ ├─vc10
|
||||||
|
│ │ │ ├─vc12
|
||||||
|
│ │ ... ...
|
||||||
|
│ └─zlib
|
||||||
|
│ ├─win32
|
||||||
|
│ ...
|
||||||
|
└─fractorium
|
||||||
|
├─archive
|
||||||
|
├─Builds
|
||||||
|
│ ├─lib
|
||||||
|
│ ├─QtCreator
|
||||||
|
│ ...
|
||||||
|
├─Data
|
||||||
|
│
|
||||||
|
├─debian
|
||||||
|
│
|
||||||
|
└─Source
|
||||||
|
```
|
||||||
|
|
||||||
|
##Begin to build
|
||||||
|
Open Qt Project `fractorium/main.pro` using Qt Creator with config like *Desktop Qt 5.5.1 MSVC2013 OpenGL 64bit*
|
||||||
|
**DO TURN OFF** "shadow build option" in "Edit build configuration" for both `Debug` and `Release`
|
||||||
|
|
||||||
|
Switch to `Release` configuration and Build!
|
||||||
|
|
||||||
|
You can find outputs `under fractorium\Bin\release` several minutes later if no error occurs.
|
||||||
|
|
||||||
|
```
|
||||||
|
Ember.dll
|
||||||
|
Ember.exp
|
||||||
|
Ember.lib
|
||||||
|
emberanimate.exe
|
||||||
|
EmberCL.dll
|
||||||
|
EmberCL.exp
|
||||||
|
EmberCL.lib
|
||||||
|
embergenome.exe
|
||||||
|
emberrender.exe
|
||||||
|
fractorium.exe
|
||||||
|
```
|
||||||
|
|
||||||
|
To run it, put exes and dlls above and these files together in one folder
|
||||||
|
```
|
||||||
|
Qt5.5.1\5.5\msvc2013_64\bin\Qt5OpenGL.dll
|
||||||
|
Qt5.5.1\5.5\msvc2013_64\bin\Qt5Widgets.dll
|
||||||
|
Qt5.5.1\5.5\msvc2013_64\bin\Qt5Core.dll
|
||||||
|
Qt5.5.1\5.5\msvc2013_64\bin\Qt5Gui.dll
|
||||||
|
Qt5.5.1\5.5\msvc2013_64\plugins\platforms\qwindows.dll (put in folder "platforms")
|
||||||
|
External\libxml2\win32\bin.msvc\libxml2.dll
|
||||||
|
External\tbb\bin\intel64\vc12\tbb.dll
|
||||||
|
fractorium\Data\dark.qss
|
||||||
|
fractorium\Data\flam3-palettes.xml
|
||||||
|
```
|
||||||
|
|
||||||
|
To run on another computer, maybe these files are needed to be shipped with:
|
||||||
|
|
||||||
|
```
|
||||||
|
MSVC2013\VC\redist\x64\Microsoft.VC120.CRT\msvcp120.dll
|
||||||
|
MSVC2013\VC\redist\x64\Microsoft.VC120.CRT\msvcr120.dll
|
||||||
|
MSVC2013\VC\redist\x64\Microsoft.VC120.CRT\vccorlib120.dll
|
||||||
|
```
|
||||||
|
|
||||||
|
or you can install *Visual C++ Redistributable Packages for Visual Studio 2013 (64 bit)*
|
||||||
|
|
||||||
|
####Output file structure
|
||||||
|
|
||||||
|
```
|
||||||
|
[YOUR FOLDER]
|
||||||
|
│ dark.qss
|
||||||
|
│ Ember.dll
|
||||||
|
│ emberanimate.exe
|
||||||
|
│ EmberCL.dll
|
||||||
|
│ embergenome.exe
|
||||||
|
│ emberrender.exe
|
||||||
|
│ flam3-palettes.xml
|
||||||
|
│ fractorium.exe
|
||||||
|
│ libxml2.dll
|
||||||
|
│ Qt5Core.dll
|
||||||
|
│ Qt5Gui.dll
|
||||||
|
│ Qt5OpenGL.dll
|
||||||
|
│ Qt5Widgets.dll
|
||||||
|
│ tbb.dll
|
||||||
|
│
|
||||||
|
│ vccorlib120.dll (optional)
|
||||||
|
│ msvcp120.dll (optional)
|
||||||
|
│ msvcr120.dll (optional)
|
||||||
|
│
|
||||||
|
└─platforms
|
||||||
|
qwindows.dll
|
||||||
|
```
|
||||||
|
|
||||||
|
####Have Fun!
|
@ -16,8 +16,11 @@ Mac OS/X (10.9+): TODO
|
|||||||
# Building from git
|
# Building from git
|
||||||
|
|
||||||
## Windows
|
## Windows
|
||||||
|
Install Git-GUI and clone `https://github.com/mfeemster/fractorium.git`
|
||||||
|
|
||||||
TODO
|
Then follow:
|
||||||
|
|
||||||
|
[**Building Guide for Fractorium Using MSVC2013 and Qt Creator (64 bit)**](Data/BuildGuideQtCreator.md)
|
||||||
|
|
||||||
## Linux
|
## Linux
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "EmberCommonPch.h"
|
#include "EmberCommonPch.h"
|
||||||
|
|
||||||
@ -73,9 +73,15 @@ static bool WriteJpeg(const char* filename, byte* image, size_t width, size_t he
|
|||||||
info.image_width = JDIMENSION(width);
|
info.image_width = JDIMENSION(width);
|
||||||
info.image_height = JDIMENSION(height);
|
info.image_height = JDIMENSION(height);
|
||||||
jpeg_set_defaults(&info);
|
jpeg_set_defaults(&info);
|
||||||
jpeg_set_quality(&info, quality, TRUE);
|
#ifdef _WIN32
|
||||||
jpeg_start_compress(&info, TRUE);
|
jpeg_set_quality(&info, quality, static_cast<boolean>(TRUE));
|
||||||
|
jpeg_start_compress(&info, static_cast<boolean>(TRUE));
|
||||||
|
//Win32:TRUE is defined in MSVC2013\Windows Kits\8.1\Include\shared\minwindef.h:"#define TRUE 1"
|
||||||
|
//cast from int to boolean in External/libjpeg/jmorecfg.h:"typedef enum { FALSE = 0, TRUE =1 } boolean;"
|
||||||
|
#else
|
||||||
|
jpeg_set_quality(&info, quality, TRUE);
|
||||||
|
jpeg_start_compress(&info, TRUE);
|
||||||
|
#endif
|
||||||
//Write comments to jpeg.
|
//Write comments to jpeg.
|
||||||
if (enableComments)
|
if (enableComments)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user