bae9d77970d439765da2f12a8857b15b074f914b
[novacoin.git] / doc / building novacoin-qt for android under Windows.txt
1 \feff1.1 Установка архиватора 7z: http://www.7-zip.org/ 
2 (при написании инструкции использовался 7-Zip 9.20 64 bit X64, но скорее всего подойдёт любая версия)
3
4 1.2 Установка msys shell:
5 -Скачайте http://sourceforge.net/projects/mingw/files/Installer/mingw-get-setup.exe/download
6 -нажмите Install
7 -директория для установки C:\MinGW
8 -поставить галочку напротив "...also install support for the graphical user interface."
9 -убрать галочки напротив "..in the start menu, and/or .." "... on the desktop"
10 -нажмите continue
11 -нажмите continue
12 -нажмите All Packages, затем MSYS
13 -поставте галочки напротив:
14 msys-autoconf-bin
15 msys-automake-bin
16 msys-base-bin
17 msys-libtool-bin
18 -нажмите Installation, Apply Changes, Apply. После завершения установки нажмите Close и закройте MinGW Installation Manager.
19
20 1.3 Установка qt-5.4.0 для Android
21 -Скачайте http://master.qt.io/archive/qt/5.4/5.4.0/qt-opensource-windows-x86-android-5.4.0.exe
22 -Запустите установщик
23 -Укажите каталог для установки(я при написании инструкции устанавливал в папку C:\Qt\Qt5.4.0)
24 -Выберите среди компонентов MinGW 4.9.1, остальные компоненты оставьте по умолчанию
25 (У меня окошко выглядит так: https://yadi.sk/i/e9W_pXTge43u5 )
26 (можно так же выбрать Android X86, и Android armv5 если собираетесь собирать под эти CPU)
27
28 1.4 Установка JAVA JDK
29 -Зайдите на сайт http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html
30 -Скачайте и установите JDK(при написании инструкции использовалась jdk-8u25-windows-i586.exe )
31
32 1.5 Установка Android SDK
33 -Скачайте http://dl.google.com/android/installer_r24.0.2-windows.exe
34 -Установите в папку C:\Android\sdk
35 -Запустите SDK Manager.exe
36 -Установите Android SDK Tools 24.0.2, Android SDK Platform-tools 21, Android SDK Build-tools 21.1.2, Google USB driver, 
37 SDK Platform 21, Google API 21, ARM EABI v7a System Image
38
39 1.6 Установка Android NDK
40 -На сайте https://developer.android.com/tools/sdk/ndk/index.html#Downloads
41 -Скачайте https://dl.google.com/android/ndk/android-ndk-r10d-windows-x86_64.exe 
42 -Установите в папку C:\Android\android-ndk-r10d  (файл android-ndk-r10d-windows-x86_64.exe это самораспоковывающийся архив, который по двойному клику распаковывается в текущую папку, поэтому лучше открыть его 7-zip и выбрать папку для распаковки самостоятельно)
43 -Добавьте путь C:\Android\android-ndk-r10d\toolchains\arm-linux-androideabi-4.9\prebuilt\windows-x86_64\bin в системную переменную PATH
44 Подробное описание как это сделать на Windows 8, Windows 7, Windows XP и Windows Vista
45 https://www.java.com/ru/download/help/path.xml
46 (только не нужно выполнять последний пункт из этой инструкции "Откройте заново окно командной строки и выполните код java." )
47
48 Проверка что вы добавили правильный путь в переменную PATH:
49 -откройте командную строку Windows(Нажмите кнопку Windows + R одновременно. Откроется окно "Выполнить", в поле открыть наберите cmd. Нажмите Ok).
50 -наберите arm-linux-androideabi-g++ -v
51 В командной строке выведется текст. В конце текста должно быть написано:
52 Thread model: posix
53 gcc version 4.9 20140827 (prerelease) (GCC)
54
55 1.7 Установка Apache Ant
56 -Зайдите на сайт https://ant.apache.org/bindownload.cgi
57 -Скачайте архив с программой: http://apache-mirror.rbc.ru/pub/apache//ant/binaries/apache-ant-1.9.4-bin.zip 
58 -Распакуйте в папку C:\Android\apache-ant-1.9.4
59
60 1.8 Добавьте новые системные переменные(Они нужны только для пункта 2. Построение зависимостей, после этого их можно убрать)
61 -Нажмите правой кнопкой мыши на "Компьютер", в открывшемся меню нажмите "Свойства", затем "Дополнительные параметры системы", потом "Переменные среды"
62 https://yadi.sk/i/GnG9HiGme46oi
63 -В "Системные переменные" нажмите "Cоздать"(ниже будет идти список "переменная и её значение")
64 ANDROID_DEV /c/Android/android-ndk-r10d/platforms/android-9/arch-arm/usr
65 AR /c/Android/android-ndk-r10d/toolchains/arm-linux-androideabi-4.9/prebuilt/windows-x86_64/bin/arm-linux-androideabi-ar
66 AS /c/Android/android-ndk-r10d/toolchains/arm-linux-androideabi-4.9/prebuilt/windows-x86_64/bin/arm-linux-androideabi-as
67 CC /c/Android/android-ndk-r10d/toolchains/arm-linux-androideabi-4.9/prebuilt/windows-x86_64/bin/arm-linux-androideabi-gcc
68 CFLAGS --sysroot=/c/Android/android-ndk-r10d/platforms/android-9/arch-arm/
69 CPP /c/Android/android-ndk-r10d/toolchains/arm-linux-androideabi-4.9/prebuilt/windows-x86_64/bin/arm-linux-androideabi-cpp
70 CPPFLAGS --sysroot=/c/Android/android-ndk-r10d/platforms/android-9/arch-arm/
71 CXX /c/Android/android-ndk-r10d/toolchains/arm-linux-androideabi-4.9/prebuilt/windows-x86_64/bin/arm-linux-androideabi-g++
72 CXXFLAGS --sysroot=/c/Android/android-ndk-r10d/platforms/android-9/arch-arm/ -I/c/Android/android-ndk-r10d/sources/cxx-stl/gnu-libstdc++/4.9/include -I/c/Android/android-ndk-r10d/sources/cxx-stl/gnu-libstdc++/4.9/libs/armeabi-v7a/include
73 LD /c/Android/android-ndk-r10d/toolchains/arm-linux-androideabi-4.9/prebuilt/windows-x86_64/bin/arm-linux-androideabi-ld
74 NDK_PROJECT_PATH C:\Android\android-ndk-r10d
75 RANLIB /c/Android/android-ndk-r10d/toolchains/arm-linux-androideabi-4.9/prebuilt/windows-x86_64/bin/arm-linux-androideabi-ranlib
76
77 2. Построение зависимостей.
78 В инструкции все зависимости сохраняются в папку C:\Android\deps
79
80 2.1 OpenSSL 
81 -Скачайте http://www.openssl.org/source/openssl-1.0.1k.tar.gz
82 -Перейдите в папку C:\MinGW\msys\1.0 и запустите msys.bat
83 Из MinGw shell выполните следующий код:
84
85 cd /c/deps/
86 tar xvfz openssl-1.0.1k.tar.gz
87 cd openssl-1.0.1k
88 Configure no-shared no-dso android-armv7
89 make
90
91 2.2 Berkeley DB
92 -Скачайте http://download.oracle.com/berkeley-db/db-6.0.20.tar.gz
93 -Из MinGw shell выполните следующий код:
94
95 cd /c/deps/
96 tar xvfz db-6.0.20.tar.gz
97 cd db-6.0.20/build_unix
98 ../dist/configure --host=arm-none-linux --enable-cxx --disable-shared --disable-replication
99 make
100
101 2.3 Boost
102 -Скачайте http://sourceforge.net/projects/boost/files/boost/1.57.0/boost_1_57_0.7z/download
103 -Распакуйте boost_1_57_0.7z в папку C:\Android\deps
104 -Откройте командную строку Windows, и выполните следующий код:
105
106 cd C:\Android\deps\boost_1_57_0
107 bootstrap.bat
108
109 Не закрывайте командную строку. Откройте файл C:\Android\deps\boost_1_57_0\project-config.jam в текстовом редакторе, удалите его содержимое, вставьте следующий текст
110
111 import option ;
112   
113 using gcc : arm : arm-linux-androideabi-g++.exe ;
114  
115 option.set keep-going : false ; 
116
117 и сохраните файл
118
119 Вернитесь в командную строку и введите:
120
121 b2 --build-type=complete --with-chrono --with-filesystem --with-program_options --with-system --with-thread toolset=gcc-arm variant=release link=static threading=multi threadapi=pthread target-os=android define=BOOST_MATH_DISABLE_FLOAT128 include=C:\Android\android-ndk-r10d\sources\cxx-stl\gnu-libstdc++\4.9\include include=C:\Android\android-ndk-r10d\sources\cxx-stl\gnu-libstdc++\4.9\libs\armeabi\include include=C:\Android\android-ndk-r10d\platforms\android-9\arch-arm\usr\include
122
123 После выполнения этой команды в папке C:\Android\deps\boost_1_57_0\stage\lib должны появиться следующие файлы:
124 libboost_atomic-gcc-mt-s-1_57.a
125 libboost_chrono-gcc-mt-s-1_57.a
126 libboost_filesystem-gcc-mt-s-1_57.a
127 libboost_program_options-gcc-mt-s-1_57.a
128 libboost_system-gcc-mt-s-1_57.a
129 libboost_thread_pthread-gcc-mt-s-1_57.a
130
131 2.4 LevelDB
132 -Зайдите на сайт https://github.com/novacoin-project/novacoin 
133 -Нажмите Download ZIP
134 -Распакуйте novacoin-master.zip в C:\Android
135 -Откройте MinGW shell (C:\MinGW\msys\1.0\msys.bat) и выполните следующий код:
136
137 cd /c/android/novacoin-master/src/leveldb
138 TARGET_OS=OS_ANDROID_CROSSCOMPILE make libleveldb.a libmemenv.a
139
140 2.5 ifaddrs
141 -Зайдите на сайт https://github.com/kmackay/android-ifaddrs
142 -Нажмите Download ZIP
143 -Откройте архив android-ifaddrs-master.zip , выберите файлы ifaddrs.c и ifaddrs.h и извлеките их в C:\Android\novacoin-master\src
144
145 3. Компиляция
146 3.1 Собираем Novacoin QT
147
148 Откройте файл src\compat.h
149 Измените #include <sys/fcntl.h> на #include <fcntl.h>
150
151 Откройте файл src\util.cpp
152 Закоментируйте строки с 59 по 61
153 //#ifndef WIN32
154 //#include <execinfo.h>
155 //#endif
156 Закоментируйте строки с 1062 по 1067
157 //#ifndef WIN32
158 //        void* pszBuffer[32];
159 //        size_t size;
160 //        size = backtrace(pszBuffer, 32);
161 //        backtrace_symbols_fd(pszBuffer, size, fileno(fileout));
162 //#endif
163
164 Откройте файл src\netbase.cpp
165 Измените #include <sys/fcntl.h> на #include <fcntl.h>
166
167 Откройте файл novacoin-qt.pro
168 Вместо 
169
170 #BOOST_LIB_SUFFIX=-mgw49-mt-s-1_55
171 #BOOST_INCLUDE_PATH=C:/deps/boost_1_55_0
172 #BOOST_LIB_PATH=C:/deps/boost_1_55_0/stage/lib
173 #BDB_INCLUDE_PATH=C:/deps/db-6.0.20/build_unix
174 #BDB_LIB_PATH=C:/deps/db-6.0.20/build_unix
175 #OPENSSL_INCLUDE_PATH=C:/deps/openssl-1.0.1j/include
176 #OPENSSL_LIB_PATH=C:/deps/openssl-1.0.1j
177
178 вставьте 
179
180 USE_UPNP=-
181 USE_QRCODE=0
182 USE_IPV6=0
183 USE_LEVELDB=1
184 USE_ASM=1
185
186 BOOST_LIB_SUFFIX=-gcc-mt-s-1_57
187 BOOST_INCLUDE_PATH=C:/Android/deps/boost_1_57_0
188 BOOST_LIB_PATH=C:/Android/deps/boost_1_57_0/stage/lib
189 BDB_INCLUDE_PATH=C:/Android/deps/db-6.0.20/build_unix
190 BDB_LIB_PATH=C:/Android/deps/db-6.0.20/build_unix
191 OPENSSL_INCLUDE_PATH=C:/Android/deps/openssl-1.0.1k/include
192 OPENSSL_LIB_PATH=C:/Android/deps/openssl-1.0.1k
193
194 Вместо
195
196 !windows|contains(USE_BUILD_INFO, 1) {
197     genbuild.depends = FORCE
198     genbuild.commands = cd $$PWD; /bin/sh share/genbuild.sh $$OUT_PWD/build/build.h
199     genbuild.target = $$OUT_PWD/build/build.h
200     PRE_TARGETDEPS += $$OUT_PWD/build/build.h
201     QMAKE_EXTRA_TARGETS += genbuild
202     DEFINES += HAVE_BUILD_INFO
203 }
204
205 вставьте
206
207 #!windows|contains(USE_BUILD_INFO, 1) {
208 #    genbuild.depends = FORCE
209 #    genbuild.commands = cd $$PWD; /bin/sh share/genbuild.sh $$OUT_PWD/build/build.h
210 #    genbuild.target = $$OUT_PWD/build/build.h
211 #    PRE_TARGETDEPS += $$OUT_PWD/build/build.h
212 #    QMAKE_EXTRA_TARGETS += genbuild
213 #    DEFINES += HAVE_BUILD_INFO
214 #}
215
216 После строки src/irc.h \ вставьте src/ifaddrs.h \ 
217 (то есть чтобы стало выглядеть так:
218 src/irc.h \
219 src/ifaddrs.h \
220 src/mruset.h \
221 )
222
223 После строки src/qt/transactiontablemodel.cpp \ вставьте  src/ifaddrs.c \
224
225 Закоментируйте строку 434 LIBS += -lrt
226 (то есть чтобы стало выглядеть так:
227 !windows:!macx {
228     DEFINES += LINUX
229 #    LIBS += -lrt
230 }
231 )
232
233 Измените строку 
234 LIBS += -lboost_system$$BOOST_LIB_SUFFIX -lboost_filesystem$$BOOST_LIB_SUFFIX -lboost_program_options$$BOOST_LIB_SUFFIX -lboost_thread$$BOOST_THREAD_LIB_SUFFIX
235 на
236 LIBS += -lboost_system$$BOOST_LIB_SUFFIX -lboost_filesystem$$BOOST_LIB_SUFFIX -lboost_program_options$$BOOST_LIB_SUFFIX -lboost_thread_pthread$$BOOST_THREAD_LIB_SUFFIX
237
238 -Откройте файл C:\Qt\Qt5.4.0\Tools\QtCreator\bin\qtcreator.exe
239 -Нажмите "Инструменты"->"Параметры", затем выберите вкладку Android
240 -Вставьте в строку "Размещение JDK" C:\Program Files (x86)\Java\jdk1.8.0_25
241 -Вставьте в строку "Размещение SDK для Android" C:\Android\sdk
242 -Вставьте в строку "Размещение NDK для Android" C:\Android\android-ndk-r10d
243 -Вставьте в строку "Программа Ant" C:\Android\apache-ant-1.9.4\bin\ant.bat
244 -Нажмите "OK"
245 -Нажмите "Файл"->"Открыть файл или проект..."
246 -Найдите "novacoin-qt.pro" и нажмите "открыть"
247 -Поставьте галочку напротив Android для armeabi-v7a(GCC 4.9, Qt 5.4.0), остальные галочки уберите
248 -Нажмите "Настроить проект"
249 -Нажмите "Проекты"->"Сборка"->"Создать шаблоны"(картинка чтобы лучше понять https://yadi.sk/i/M8mhG2tce4cEy)
250 -Нажмите "Завершить"
251 -В проекте novacoin-qt выберете Другие файлы->android->AndroidManifest.xml и задайте имя пакета, имя приложения, иконки приложения(Иконки находятся в папке C:\Android\novacoin-master\src\qt\res\icons) (Для Google Play Market иконка должна быть не менее 512x512)(https://yadi.sk/i/oY-OmnrWe4cTY)
252 -Возьмите ваш Android телефон/планшет(версия должна быть от 2.3 и выше)
253 -Перейдите в "Настройки"->"Приложения".
254 -Поставьте галочку напротив "Неизвестные источники"
255 -Перейдите в "Разработка"
256 -Поставьте галочки напротив "Отладка по USB"
257 -Подключите через USB ваш телефон/планшет к компьютеру. Не выбирайте опцию в телефоне/планшете "Включить USB-накопитель"
258 -Должно найтись Android устройство. https://yadi.sk/i/wFWZLxtie4DrN
259 Если Windows не может найти драйвер для устройства, то укажите самостоятельно в папке C:\Android\sdk\extras\google\usb_driver есть файл android_winusb.inf
260 -В QtCreator'е нажмите на зеленого робота и выберите Сборка: Выпуск
261 -Нажмите зеленую стрелку(Запустить)(https://yadi.sk/i/hKHKL_Phe4EFL)
262 -Выберите свой телефон/планшет, нажмите OK и ждите завершения компиляции.
263 -После завершения компиляции Novacoin-Qt будет установлен на ваш телефон/планшет и запущен. А в папке C:\Android\build-novacoin-qt-Android_armeabi_v7a_GCC_4_9_Qt_5_4_0-Release\android-build\bin будет файл QtApp-debug.apk. Переименуйте его в Novacoin-Qt-0.5.1-debug.apk и можно распростронять :)