mirror of
https://github.com/JulianGro/overte.git
synced 2025-04-16 02:01:30 +02:00
complete successful apk creation via androiddeployqt
This commit is contained in:
parent
fe0d9cc034
commit
a04ee42c0d
8 changed files with 23 additions and 392 deletions
|
@ -2,43 +2,6 @@
|
|||
|
||||
<!-- IMPORTANT: Do not manually manipulate this automatically generated file, changes will be gone after the next build! -->
|
||||
|
||||
<manifest package="${ANDROID_APK_PACKAGE}" xmlns:android="http://schemas.android.com/apk/res/android" android:versionName="1.0" android:versionCode="1" android:installLocation="auto">
|
||||
<uses-sdk android:minSdkVersion="${ANDROID_API_LEVEL}" />
|
||||
<application android:name="org.qtproject.qt5.android.bindings.QtApplication" android:debuggable="${ANDROID_APK_DEBUGGABLE}" android:label="@string/ApplicationName">
|
||||
<activity android:configChanges="orientation|uiMode|screenLayout|screenSize|smallestScreenSize|locale|fontScale|keyboard|keyboardHidden|navigation"
|
||||
android:name="org.qtproject.qt5.android.bindings.QtActivity"
|
||||
android:label="@string/app_name"
|
||||
android:screenOrientation="unspecified"
|
||||
${ANDROID_APK_THEME}>
|
||||
<intent-filter>
|
||||
<action android:name="android.intent.action.MAIN"/>
|
||||
<category android:name="android.intent.category.LAUNCHER"/>
|
||||
</intent-filter>
|
||||
<meta-data android:name="android.app.lib_name" android:value="-- %%INSERT_APP_LIB_NAME%% --"/>
|
||||
<meta-data android:name="android.app.qt_sources_resource_id" android:resource="@array/qt_sources"/>
|
||||
<meta-data android:name="android.app.repository" android:value="default"/>
|
||||
<meta-data android:name="android.app.qt_libs_resource_id" android:resource="@array/qt_libs"/>
|
||||
<meta-data android:name="android.app.bundled_libs_resource_id" android:resource="@array/bundled_libs"/>
|
||||
<!-- Deploy Qt libs as part of package -->
|
||||
<meta-data android:name="android.app.bundle_local_qt_libs" android:value="-- %%BUNDLE_LOCAL_QT_LIBS%% --"/>
|
||||
<meta-data android:name="android.app.bundled_in_lib_resource_id" android:resource="@array/bundled_in_lib"/>
|
||||
<meta-data android:name="android.app.bundled_in_assets_resource_id" android:resource="@array/bundled_in_assets"/>
|
||||
<!-- Run with local libs -->
|
||||
<meta-data android:name="android.app.use_local_qt_libs" android:value="-- %%USE_LOCAL_QT_LIBS%% --"/>
|
||||
<meta-data android:name="android.app.libs_prefix" android:value="/data/local/tmp/qt/"/>
|
||||
<meta-data android:name="android.app.load_local_libs" android:value="-- %%INSERT_LOCAL_LIBS%% --"/>
|
||||
<meta-data android:name="android.app.load_local_jars" android:value="-- %%INSERT_LOCAL_JARS%% --"/>
|
||||
<meta-data android:name="android.app.static_init_classes" android:value="-- %%INSERT_INIT_CLASSES%% --"/>
|
||||
<!-- Messages maps -->
|
||||
<meta-data android:value="@string/ministro_not_found_msg" android:name="android.app.ministro_not_found_msg"/>
|
||||
<meta-data android:value="@string/ministro_needed_msg" android:name="android.app.ministro_needed_msg"/>
|
||||
<meta-data android:value="@string/fatal_error_msg" android:name="android.app.fatal_error_msg"/>
|
||||
<!-- Messages maps -->
|
||||
</activity>
|
||||
</application>
|
||||
|
||||
<!-- %%INSERT_PERMISSIONS -->
|
||||
<uses-permission android:name="android.permission.INTERNET"/>
|
||||
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
|
||||
<!-- %%INSERT_FEATURES -->
|
||||
<manifest android:versionName="1.0" android:versionCode="1">
|
||||
|
||||
</manifest>
|
||||
|
|
|
@ -1,272 +0,0 @@
|
|||
#*********************************************************#
|
||||
#* File: Apk.cmake *
|
||||
#* Android apk tools
|
||||
#*
|
||||
#* Copyright (C) 2002-2013 The PixelLight Team (http://www.pixellight.org/)
|
||||
#*
|
||||
#* This file is part of PixelLight.
|
||||
#*
|
||||
#* Permission is hereby granted, free of charge, to any person obtaining a copy of this software
|
||||
#* and associated documentation files (the "Software"), to deal in the Software without
|
||||
#* restriction, including without limitation the rights to use, copy, modify, merge, publish,
|
||||
#* distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the
|
||||
#* Software is furnished to do so, subject to the following conditions:
|
||||
#*
|
||||
#* The above copyright notice and this permission notice shall be included in all copies or
|
||||
#* substantial portions of the Software.
|
||||
#*
|
||||
#* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
|
||||
#* BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||
#* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
|
||||
#* DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||
#* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
#*********************************************************#
|
||||
|
||||
|
||||
##################################################
|
||||
## Options
|
||||
##################################################
|
||||
set(ANDROID_APK_CREATE "1" CACHE BOOL "Create apk file?")
|
||||
set(ANDROID_APK_INSTALL "1" CACHE BOOL "Install created apk file on the device automatically?")
|
||||
set(ANDROID_APK_RUN "1" CACHE BOOL "Run created apk file on the device automatically? (installs it automatically as well, \"ANDROID_APK_INSTALL\"-option is ignored)")
|
||||
set(ANDROID_APK_TOP_LEVEL_DOMAIN "io" CACHE STRING "Top level domain name of the organization (follow the package naming conventions (http://en.wikipedia.org/wiki/Java_package#Package_naming_conventions))")
|
||||
set(ANDROID_APK_DOMAIN "highfidelity" CACHE STRING "Organization's domain (follow the package naming conventions (http://en.wikipedia.org/wiki/Java_package#Package_naming_conventions))")
|
||||
set(ANDROID_APK_SUBDOMAIN "gvrinterface" CACHE STRING "Any subdomains (follow the package naming conventions (http://en.wikipedia.org/wiki/Java_package#Package_naming_conventions))")
|
||||
set(ANDROID_APK_FULLSCREEN "1" CACHE BOOL "Run the application in fullscreen? (no status/title bar)")
|
||||
set(ANDROID_APK_RELEASE "0" CACHE BOOL "Create apk file ready for release? (signed, you have to enter a password during build, do also setup \"ANDROID_APK_SIGNER_KEYSTORE\" and \"ANDROID_APK_SIGNER_ALIAS\")")
|
||||
set(ANDROID_APK_SIGNER_KEYSTORE "~/my-release-key.keystore" CACHE STRING "Keystore for signing the apk file (only required for release apk)")
|
||||
set(ANDROID_APK_SIGNER_ALIAS "myalias" CACHE STRING "Alias for signing the apk file (only required for release apk)")
|
||||
|
||||
|
||||
##################################################
|
||||
## Variables
|
||||
##################################################
|
||||
set(ANDROID_THIS_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}) # Directory this CMake file is in
|
||||
|
||||
|
||||
##################################################
|
||||
## MACRO: android_create_apk
|
||||
##
|
||||
## Create/copy Android apk related files
|
||||
##
|
||||
## @param name
|
||||
## Name of the project (e.g. "MyProject"), this will also be the name of the created apk file
|
||||
## @param apk_directory
|
||||
## Directory were to construct the apk file in (e.g. "${CMAKE_BINARY_DIR}/apk")
|
||||
## @param shared_libraries
|
||||
## List of shared libraries (absolute filenames) this application is using, these libraries are copied into the apk file and will be loaded automatically within a generated Java file - Lookout! The order is important due to shared library dependencies!
|
||||
## @param assets
|
||||
## List of assets to copy into the apk file (absolute filenames, wildcards like "*.*" are allowed)
|
||||
## @param data_directory
|
||||
## Subdirectory within the apk asset directory to copy the "assets"-files into (e.g. "Data")
|
||||
##
|
||||
## @remarks
|
||||
## Requires the following tools to be found automatically
|
||||
## - "android" (part of the Android SDK)
|
||||
## - "adb" (part of the Android SDK)
|
||||
## - "ant" (type e.g. "sudo apt-get install ant" on your Linux system to install Ant)
|
||||
## - "jarsigner" (part of the JDK)
|
||||
## - "zipalign" (part of the Android SDK)
|
||||
##################################################
|
||||
macro(android_create_apk name apk_directory shared_libraries static_libraries jar_libraries assets data_directory)
|
||||
if(ANDROID_APK_CREATE)
|
||||
# Construct the current package name and theme
|
||||
set(ANDROID_APK_PACKAGE "${ANDROID_APK_TOP_LEVEL_DOMAIN}.${ANDROID_APK_DOMAIN}.${ANDROID_APK_SUBDOMAIN}")
|
||||
|
||||
set(ANDROID_NAME ${name})
|
||||
if(CMAKE_BUILD_TYPE MATCHES Debug)
|
||||
set(ANDROID_APK_DEBUGGABLE "true")
|
||||
set(ANDROID_APK_RELEASE_LOCAL "0")
|
||||
else()
|
||||
set(ANDROID_APK_DEBUGGABLE "false")
|
||||
set(ANDROID_APK_RELEASE_LOCAL ${ANDROID_APK_RELEASE})
|
||||
endif()
|
||||
|
||||
# Create "AndroidManifest.xml"
|
||||
configure_file("${ANDROID_THIS_DIRECTORY}/AndroidManifest.xml.in" "${apk_directory}/AndroidManifest.xml")
|
||||
|
||||
# Create "res/values/strings.xml"
|
||||
configure_file("${ANDROID_THIS_DIRECTORY}/strings.xml.in" "${apk_directory}/res/values/strings.xml")
|
||||
|
||||
# Get a list of libraries to load in (e.g. "PLCore;PLMath" etc.)
|
||||
set(ANDROID_SHARED_LIBRARIES_TO_LOAD "")
|
||||
foreach(value ${shared_libraries})
|
||||
# "value" is e.g. "/home/cofenberg/pl_ndk/Bin-Linux-ndk/Runtime/armeabi/libPLCore.so"
|
||||
get_filename_component(shared_library_filename ${value} NAME_WE)
|
||||
|
||||
# "shared_library_filename" is e.g. "libPLCore", but we need "PLCore"
|
||||
string(LENGTH ${shared_library_filename} shared_library_filename_length)
|
||||
math(EXPR shared_library_filename_length ${shared_library_filename_length}-3)
|
||||
string(SUBSTRING ${shared_library_filename} 3 ${shared_library_filename_length} shared_library_filename)
|
||||
|
||||
# "shared_library_filename" is now e.g. "PLCore", this is what we want -> Add it to the list
|
||||
set(ANDROID_SHARED_LIBRARIES_TO_LOAD ${ANDROID_SHARED_LIBRARIES_TO_LOAD} ${shared_library_filename})
|
||||
endforeach()
|
||||
|
||||
# Create Java file which is responsible for loading in the required shared libraries (the content of "ANDROID_SHARED_LIBRARIES_TO_LOAD" is used for this)
|
||||
configure_file("${ANDROID_THIS_DIRECTORY}/LoadLibraries.java.in" "${apk_directory}/src/${ANDROID_APK_TOP_LEVEL_DOMAIN}/${ANDROID_APK_DOMAIN}/${ANDROID_APK_SUBDOMAIN}/LoadLibraries.java")
|
||||
|
||||
# Create the directory for the libraries
|
||||
add_custom_command(TARGET ${ANDROID_NAME}
|
||||
PRE_BUILD
|
||||
COMMAND ${CMAKE_COMMAND} -E remove_directory "${apk_directory}/libs"
|
||||
)
|
||||
add_custom_command(TARGET ${ANDROID_NAME}
|
||||
PRE_BUILD
|
||||
COMMAND ${CMAKE_COMMAND} -E make_directory "${apk_directory}/libs/${ARM_TARGET}"
|
||||
)
|
||||
|
||||
# Copy the used shared libraries
|
||||
foreach(value ${shared_libraries})
|
||||
add_custom_command(TARGET ${ANDROID_NAME}
|
||||
POST_BUILD
|
||||
COMMAND ${CMAKE_COMMAND} -E copy ${value} "${apk_directory}/libs/${ARM_TARGET}"
|
||||
)
|
||||
endforeach()
|
||||
|
||||
# Copy the used shared libraries
|
||||
foreach(value ${static_libraries})
|
||||
add_custom_command(TARGET ${ANDROID_NAME}
|
||||
POST_BUILD
|
||||
COMMAND ${CMAKE_COMMAND} -E copy ${value} "${apk_directory}/libs/${ARM_TARGET}"
|
||||
)
|
||||
endforeach()
|
||||
|
||||
# Copy any required external jars to the libs folder
|
||||
foreach(value ${jar_libraries})
|
||||
add_custom_command(TARGET ${ANDROID_NAME}
|
||||
POST_BUILD
|
||||
COMMAND ${CMAKE_COMMAND} -E copy ${value} "${apk_directory}/libs/"
|
||||
)
|
||||
endforeach()
|
||||
|
||||
# Create "build.xml", "default.properties", "local.properties" and "proguard.cfg" files
|
||||
add_custom_command(TARGET ${ANDROID_NAME}
|
||||
COMMAND android update project -t android-${ANDROID_API_LEVEL} --name ${ANDROID_NAME} --path "${apk_directory}"
|
||||
)
|
||||
|
||||
# Copy assets
|
||||
add_custom_command(TARGET ${ANDROID_NAME}
|
||||
PRE_BUILD
|
||||
COMMAND ${CMAKE_COMMAND} -E remove_directory "${apk_directory}/assets"
|
||||
)
|
||||
add_custom_command(TARGET ${ANDROID_NAME}
|
||||
PRE_BUILD
|
||||
COMMAND ${CMAKE_COMMAND} -E make_directory "${apk_directory}/assets/${data_directory}"
|
||||
)
|
||||
foreach(value ${assets})
|
||||
android_copy_files(${value} "${apk_directory}/assets/${data_directory}")
|
||||
endforeach()
|
||||
|
||||
# In case of debug build, do also copy gdbserver
|
||||
if(CMAKE_BUILD_TYPE MATCHES Debug)
|
||||
add_custom_command(TARGET ${ANDROID_NAME}
|
||||
POST_BUILD
|
||||
COMMAND ${CMAKE_COMMAND} -E copy ${CMAKE_GDBSERVER} "${apk_directory}/libs/${ARM_TARGET}"
|
||||
)
|
||||
endif()
|
||||
|
||||
# Uninstall previous version from the device/emulator (else we may get e.g. signature conflicts)
|
||||
add_custom_command(TARGET ${ANDROID_NAME}
|
||||
COMMAND adb uninstall ${ANDROID_APK_PACKAGE}
|
||||
)
|
||||
|
||||
# Build the apk file
|
||||
if(ANDROID_APK_RELEASE_LOCAL)
|
||||
# Let Ant create the unsigned apk file
|
||||
add_custom_command(TARGET ${ANDROID_NAME}
|
||||
COMMAND ant release
|
||||
WORKING_DIRECTORY "${apk_directory}"
|
||||
)
|
||||
|
||||
# Sign the apk file
|
||||
add_custom_command(TARGET ${ANDROID_NAME}
|
||||
COMMAND jarsigner -verbose -keystore ${ANDROID_APK_SIGNER_KEYSTORE} bin/${ANDROID_NAME}-unsigned.apk ${ANDROID_APK_SIGNER_ALIAS}
|
||||
WORKING_DIRECTORY "${apk_directory}"
|
||||
)
|
||||
|
||||
# Align the apk file
|
||||
add_custom_command(TARGET ${ANDROID_NAME}
|
||||
COMMAND zipalign -v -f 4 bin/${ANDROID_NAME}-unsigned.apk bin/${ANDROID_NAME}.apk
|
||||
WORKING_DIRECTORY "${apk_directory}"
|
||||
)
|
||||
|
||||
# Install current version on the device/emulator
|
||||
if(ANDROID_APK_INSTALL OR ANDROID_APK_RUN)
|
||||
add_custom_command(TARGET ${ANDROID_NAME}
|
||||
COMMAND adb install -r bin/${ANDROID_NAME}.apk
|
||||
WORKING_DIRECTORY "${apk_directory}"
|
||||
)
|
||||
endif()
|
||||
else()
|
||||
# Let Ant create the unsigned apk file
|
||||
add_custom_command(TARGET ${ANDROID_NAME}
|
||||
COMMAND ant debug
|
||||
WORKING_DIRECTORY "${apk_directory}"
|
||||
)
|
||||
|
||||
# Install current version on the device/emulator
|
||||
if(ANDROID_APK_INSTALL OR ANDROID_APK_RUN)
|
||||
add_custom_command(TARGET ${ANDROID_NAME}
|
||||
COMMAND adb install -r bin/${ANDROID_NAME}-debug.apk
|
||||
WORKING_DIRECTORY "${apk_directory}"
|
||||
)
|
||||
endif()
|
||||
endif()
|
||||
|
||||
# Start the application
|
||||
if(ANDROID_APK_RUN)
|
||||
add_custom_command(TARGET ${ANDROID_NAME}
|
||||
COMMAND adb shell am start -n ${ANDROID_APK_PACKAGE}/${ANDROID_APK_PACKAGE}.LoadLibraries
|
||||
)
|
||||
endif()
|
||||
endif()
|
||||
endmacro(android_create_apk name apk_directory shared_libraries assets data_directory)
|
||||
|
||||
##################################################
|
||||
## MACRO: android_copy_files
|
||||
##
|
||||
## Copy files from one place to another using wildcards
|
||||
##################################################
|
||||
macro(android_copy_files src dest)
|
||||
# Get path
|
||||
get_filename_component(path ${src} PATH)
|
||||
|
||||
# Get exclude option
|
||||
set(exclude)
|
||||
if("${ARGV2}" STREQUAL "EXCLUDE")
|
||||
set(exclude ${ARGV3})
|
||||
endif()
|
||||
|
||||
# Find files
|
||||
file(GLOB_RECURSE files RELATIVE ${path} ${src})
|
||||
|
||||
# Find files
|
||||
foreach(file ${files})
|
||||
# Get source and destination file
|
||||
set(src_file ${path}/${file})
|
||||
set(dst_file ${dest}/${file})
|
||||
|
||||
# Check exclude expression
|
||||
set(copy 1)
|
||||
if(exclude)
|
||||
if(file MATCHES ${exclude})
|
||||
set(copy 0)
|
||||
endif()
|
||||
endif()
|
||||
|
||||
# Process file
|
||||
if(copy EQUAL 1)
|
||||
# Create output directory
|
||||
get_filename_component(dst_path ${dst_file} PATH)
|
||||
file(MAKE_DIRECTORY ${dst_path})
|
||||
|
||||
# Copy file
|
||||
add_custom_command(TARGET ${ANDROID_NAME}
|
||||
PRE_BUILD
|
||||
COMMAND ${CMAKE_COMMAND} -E copy ${src_file} ${dst_file} VERBATIM
|
||||
)
|
||||
endif()
|
||||
endforeach(file ${files})
|
||||
endmacro(android_copy_files src dest)
|
||||
|
|
@ -1,19 +0,0 @@
|
|||
// IMPORTANT: Do not manually manipulate this automatically generated file, changes will be gone after the next build!
|
||||
|
||||
package ${ANDROID_APK_TOP_LEVEL_DOMAIN}.${ANDROID_APK_DOMAIN}.${ANDROID_APK_SUBDOMAIN};
|
||||
|
||||
import android.app.NativeActivity;
|
||||
|
||||
public class LoadLibraries extends NativeActivity {
|
||||
|
||||
static {
|
||||
// List of libraries to load in (e.g. "PLCore;PLMath" etc.)
|
||||
String sharedLibrariesToLoad = "${ANDROID_SHARED_LIBRARIES_TO_LOAD}";
|
||||
|
||||
// Load in all shared libraries
|
||||
String [] libraries = sharedLibrariesToLoad.split(";");
|
||||
for (int i=0; i<libraries.length; i++)
|
||||
System.loadLibrary(libraries[i]);
|
||||
}
|
||||
|
||||
}
|
|
@ -35,19 +35,16 @@ macro(qt_create_apk)
|
|||
endif ()
|
||||
|
||||
# Create "AndroidManifest.xml"
|
||||
configure_file("${ANDROID_THIS_DIRECTORY}/AndroidManifest.xml.in" "${ANDROID_APK_DIR}/AndroidManifest.xml")
|
||||
|
||||
# Create "res/values/strings.xml"
|
||||
configure_file("${ANDROID_THIS_DIRECTORY}/strings.xml.in" "${ANDROID_APK_DIR}/res/values/strings.xml")
|
||||
configure_file("${ANDROID_THIS_DIRECTORY}/AndroidManifest.xml.in" "${ANDROID_APK_BUILD_DIR}/AndroidManifest.xml")
|
||||
|
||||
# figure out where the qt dir is
|
||||
get_filename_component(QT_DIR "${QT_CMAKE_PREFIX_PATH}/../../../" ABSOLUTE)
|
||||
get_filename_component(QT_DIR "${QT_CMAKE_PREFIX_PATH}/../../" ABSOLUTE)
|
||||
|
||||
# find androiddeployqt
|
||||
find_program(ANDROID_DEPLOY_QT androiddeployqt HINTS "${_QT_DIR}/bin")
|
||||
find_program(ANDROID_DEPLOY_QT androiddeployqt HINTS "${QT_DIR}/bin")
|
||||
|
||||
# set the path to our app shared library
|
||||
set(EXECUTABLE_DESTINATION_PATH "${CMAKE_BINARY_DIR}/libs/${ANDROID_ABI}/lib${TARGET_NAME}.so")
|
||||
set(EXECUTABLE_DESTINATION_PATH "${ANDROID_APK_OUTPUT_DIR}/libs/${ANDROID_ABI}/lib${TARGET_NAME}.so")
|
||||
|
||||
# add our dependencies to the deployment file
|
||||
get_property(_DEPENDENCIES TARGET ${TARGET_NAME} PROPERTY INTERFACE_LINK_LIBRARIES)
|
||||
|
@ -65,8 +62,13 @@ macro(qt_create_apk)
|
|||
|
||||
configure_file("${ANDROID_THIS_DIRECTORY}/deployment-file.json.in" "${TARGET_NAME}-deployment.json")
|
||||
|
||||
# use androiddeployqt to create the apk
|
||||
add_custom_command(TARGET ${TARGET_NAME}
|
||||
COMMAND ${ANDROID_DEPLOY_QT} --input "${TARGET_NAME}-deployment.json" --output "${ANDROID_APK_OUTPUT_DIR}" --deployment bundled "\\$(ARGS)"
|
||||
)
|
||||
|
||||
# Uninstall previous version from the device/emulator (else we may get e.g. signature conflicts)
|
||||
add_custom_command(TARGET ${TARGET_NAME}
|
||||
COMMAND adb uninstall ${ANDROID_APK_PACKAGE}
|
||||
)
|
||||
)
|
||||
endmacro()
|
|
@ -2,7 +2,7 @@
|
|||
"qt": "@QT_DIR@",
|
||||
"sdk": "@ANDROID_SDK_ROOT@",
|
||||
"ndk": "@ANDROID_NDK@",
|
||||
"toolchain-prefix": "@$ANDROID_TOOLCHAIN_MACHINE_NAME@",
|
||||
"toolchain-prefix": "@ANDROID_TOOLCHAIN_MACHINE_NAME@",
|
||||
"tool-prefix": "@ANDROID_TOOLCHAIN_MACHINE_NAME@",
|
||||
"toolchain-version": "@ANDROID_COMPILER_VERSION@",
|
||||
"ndk-host": "@ANDROID_NDK_HOST_SYSTEM_NAME@",
|
||||
|
|
|
@ -1,7 +0,0 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
|
||||
<!-- IMPORTANT: Do not manually manipulate this automatically generated file, changes will be gone after the next build! -->
|
||||
|
||||
<resources>
|
||||
<string name="ApplicationName">${ANDROID_APP_NAME}</string>
|
||||
</resources>
|
|
@ -1,6 +1,11 @@
|
|||
set(TARGET_NAME gvr-interface)
|
||||
|
||||
set(${TARGET_NAME}_SHARED true)
|
||||
set(ANDROID_APK_BUILD_DIR "${CMAKE_CURRENT_BINARY_DIR}/apk-build")
|
||||
set(ANDROID_APK_OUTPUT_DIR "${CMAKE_CURRENT_BINARY_DIR}/apk")
|
||||
|
||||
set(CMAKE_LIBRARY_OUTPUT_DIRECTORY "${ANDROID_APK_OUTPUT_DIR}/libs/${ANDROID_ABI}")
|
||||
set(BUILD_SHARED_LIBS ON)
|
||||
|
||||
setup_hifi_library()
|
||||
|
||||
include_glm()
|
||||
|
@ -15,6 +20,5 @@ set(ANDROID_APP_NAME Interface)
|
|||
set(ANDROID_API_LEVEL 19)
|
||||
set(ANDROID_APK_PACKAGE io.highfidelity.gvrinterface)
|
||||
set(ANDROID_APK_FULLSCREEN true)
|
||||
set(ANDROID_APK_DIR "${CMAKE_CURRENT_BINARY_DIR}/apk")
|
||||
|
||||
qt_create_apk()
|
|
@ -9,49 +9,9 @@
|
|||
// See the accompanying file LICENSE or http://www.apache.org/licenses/LICENSE-2.0.html
|
||||
//
|
||||
|
||||
#include <android_native_app_glue.h>
|
||||
#include <android/log.h>
|
||||
#include <QtGui/qguiapplication.h>
|
||||
|
||||
// usage of log
|
||||
#define APP_NAME "Interface"
|
||||
|
||||
// usage of log
|
||||
#define LOGINFO(x...) __android_log_print(ANDROID_LOG_INFO, APP_NAME, x)
|
||||
|
||||
// handle commands
|
||||
static void custom_handle_cmd(struct android_app* app, int32_t cmd) {
|
||||
switch(cmd) {
|
||||
case APP_CMD_INIT_WINDOW:
|
||||
LOGINFO("GearVR Interface, reporting for duty");
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void android_main(struct android_app* state) {
|
||||
// Make sure glue isn't stripped.
|
||||
app_dummy();
|
||||
|
||||
int events;
|
||||
|
||||
// set up so when commands happen we call our custom handler
|
||||
state->onAppCmd = custom_handle_cmd;
|
||||
|
||||
while (1) {
|
||||
struct android_poll_source* source;
|
||||
|
||||
// we block for events
|
||||
while (ALooper_pollAll(-1, NULL, &events, (void**)&source) >= 0) {
|
||||
|
||||
// Process this event.
|
||||
if (source != NULL) {
|
||||
source->process(state, source);
|
||||
}
|
||||
|
||||
// Check if we are exiting.
|
||||
if (state->destroyRequested != 0) {
|
||||
LOGINFO("We are exiting");
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
int main(int argc, char* argv[]) {
|
||||
QGuiApplication app(argc, argv);
|
||||
return app.exec();
|
||||
}
|
Loading…
Reference in a new issue