Je ne parviens pas à compiler correctement mon NDK dans Android Studio. Chaque fois que j'essaie de compiler, j'obtiens l'erreur suivante.
Erreur: L'exécution a échoué pour la tâche ': app: ndkBuild' . Un problème est survenu au démarrage du processus 'commande' ndk-build.cmd ''
J'ai la configuration suivante
Et mon fichier build.gradle est le suivant.
import org.Apache.tools.ant.taskdefs.condition.Os
apply plugin: 'com.Android.application'
Android {
compileSdkVersion 21
buildToolsVersion "21.1.2"
defaultConfig {
applicationId "edu.uky.cs.www.diagramaphone"
minSdkVersion 14
targetSdkVersion 21
versionCode 1
versionName "1.0"
sourceSets.main{
jniLibs.srcDir 'src/main/libs'
jni.srcDirs = [] //disable automatic ndk-build call
}
project.ext.versionCodes = ['armeabi':1, 'armeabi-v7a':2, 'arm64-v8a':3, 'mips':5, 'mips64':6, 'x86':8, 'x86_64':9] //versionCode digit for each supported ABI, with 64bit>32bit and x86>armeabi-*
Android.applicationVariants.all { variant ->
// assign different version code for each output
variant.outputs.each { output ->
output.versionCodeOverride =
project.ext.versionCodes.get(output.getFilter(com.Android.build.OutputFile.ABI), 0) * 1000000 + defaultConfig.versionCode
}
}
// call regular ndk-build(.cmd) script from app directory
task ndkBuild(type: Exec) {
if (Os.isFamily(Os.FAMILY_WINDOWS)) {
commandLine 'ndk-build.cmd', '-C', file('src/main').absolutePath
} else {
commandLine 'ndk-build', '-C', file('src/main').absolutePath
}
}
tasks.withType(JavaCompile) {
compileTask -> compileTask.dependsOn ndkBuild
}
//ndk {
// moduleName "shape-detect"
//cFlags "-DANDROID_NDK -D_DEBUG DNULL=0" // Define some macros
//ldLibs "EGL", "GLESv3", "dl", "log" // Link with these libraries!
//stl "stlport_shared" // Use shared stlport library
//}
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-Android.txt'), 'proguard-rules.pro'
}
}
}
dependencies {
compile fileTree(include: ['*.jar'], dir: 'libs')
compile 'com.Android.support:appcompat-v7:21.0.3'
compile project(':libraries:tess-two')
compile project(':libraries:opencv')
}
À ce stade, je suis perdu quant à ce qui peut être faux. J'ai suivi plusieurs tutoriels pour essayer de configurer le NDK pour qu'il fonctionne correctement, mais l'erreur ne cesse de s'afficher. Est-ce que quelqu'un ici peut donner quelques informations sur ce que je dois faire pour que le NDK soit compilé?
EDIT: Voici le message entier qui se passe.
Information:Gradle tasks [:app:assembleDebug]
:app:preBuild UP-TO-DATE
:app:preDebugBuild UP-TO-DATE
:app:compileDebugNdk UP-TO-DATE
:app:checkDebugManifest
:app:preReleaseBuild UP-TO-DATE
:libraries:opencv:compileLint
:libraries:opencv:copyReleaseLint UP-TO-DATE
:libraries:opencv:mergeReleaseProguardFiles UP-TO-DATE
:libraries:opencv:preBuild UP-TO-DATE
:libraries:opencv:preReleaseBuild UP-TO-DATE
:libraries:opencv:checkReleaseManifest
:libraries:opencv:prepareReleaseDependencies
:libraries:opencv:compileReleaseAidl UP-TO-DATE
:libraries:opencv:compileReleaseRenderscript UP-TO-DATE
:libraries:opencv:generateReleaseBuildConfig UP-TO-DATE
:libraries:opencv:generateReleaseAssets UP-TO-DATE
:libraries:opencv:mergeReleaseAssets UP-TO-DATE
:libraries:opencv:generateReleaseResValues UP-TO-DATE
:libraries:opencv:generateReleaseResources UP-TO-DATE
:libraries:opencv:packageReleaseResources UP-TO-DATE
:libraries:opencv:processReleaseManifest UP-TO-DATE
:libraries:opencv:processReleaseResources UP-TO-DATE
:libraries:opencv:generateReleaseSources UP-TO-DATE
:libraries:opencv:compileReleaseJava UP-TO-DATE
:libraries:opencv:processReleaseJavaRes UP-TO-DATE
:libraries:opencv:packageReleaseJar UP-TO-DATE
:libraries:opencv:compileReleaseNdk UP-TO-DATE
:libraries:opencv:packageReleaseJniLibs UP-TO-DATE
:libraries:opencv:packageReleaseLocalJar UP-TO-DATE
:libraries:opencv:packageReleaseRenderscript UP-TO-DATE
:libraries:opencv:bundleRelease UP-TO-DATE
:libraries:tess-two:compileLint
:libraries:tess-two:copyReleaseLint UP-TO-DATE
:libraries:tess-two:mergeReleaseProguardFiles UP-TO-DATE
:libraries:tess-two:preBuild UP-TO-DATE
:libraries:tess-two:preReleaseBuild UP-TO-DATE
:libraries:tess-two:checkReleaseManifest
:libraries:tess-two:prepareReleaseDependencies
:libraries:tess-two:compileReleaseAidl UP-TO-DATE
:libraries:tess-two:compileReleaseRenderscript UP-TO-DATE
:libraries:tess-two:generateReleaseBuildConfig UP-TO-DATE
:libraries:tess-two:generateReleaseAssets UP-TO-DATE
:libraries:tess-two:mergeReleaseAssets UP-TO-DATE
:libraries:tess-two:generateReleaseResValues UP-TO-DATE
:libraries:tess-two:generateReleaseResources UP-TO-DATE
:libraries:tess-two:packageReleaseResources UP-TO-DATE
:libraries:tess-two:processReleaseManifest UP-TO-DATE
:libraries:tess-two:processReleaseResources UP-TO-DATE
:libraries:tess-two:generateReleaseSources UP-TO-DATE
:libraries:tess-two:compileReleaseJava UP-TO-DATE
:libraries:tess-two:processReleaseJavaRes UP-TO-DATE
:libraries:tess-two:packageReleaseJar UP-TO-DATE
:libraries:tess-two:compileReleaseNdk UP-TO-DATE
:libraries:tess-two:packageReleaseJniLibs UP-TO-DATE
:libraries:tess-two:packageReleaseLocalJar UP-TO-DATE
:libraries:tess-two:packageReleaseRenderscript UP-TO-DATE
:libraries:tess-two:bundleRelease UP-TO-DATE
:app:prepareComAndroidSupportAppcompatV72103Library UP-TO-DATE
:app:prepareComAndroidSupportSupportV42103Library UP-TO-DATE
:app:prepareDiagramaphoneLibrariesOpencvUnspecifiedLibrary UP-TO-DATE
:app:prepareDiagramaphoneLibrariesTessTwoUnspecifiedLibrary UP-TO-DATE
:app:prepareDebugDependencies
:app:compileDebugAidl UP-TO-DATE
:app:compileDebugRenderscript UP-TO-DATE
:app:generateDebugBuildConfig UP-TO-DATE
:app:generateDebugAssets UP-TO-DATE
:app:mergeDebugAssets UP-TO-DATE
:app:generateDebugResValues UP-TO-DATE
:app:generateDebugResources UP-TO-DATE
:app:mergeDebugResources UP-TO-DATE
:app:processDebugManifest UP-TO-DATE
:app:processDebugResources UP-TO-DATE
:app:generateDebugSources UP-TO-DATE
:app:ndkBuild FAILED
Error:Execution failed for task ':app:ndkBuild'.
> A problem occurred starting process 'command 'ndk-build.cmd''
Information:BUILD FAILED
Information:Total time: 2.226 secs
Information:1 error
Information:0 warnings
Information:See complete output in console
J'ai rencontré ce genre de problème. Tout d'abord, vous devez donner votre chemin NDK dans local.properties
de votre application.
par exemple. ndk.dir=/home/user/bin/Android_ndk/Android-ndk-r10e
Ensuite, dans mon fichier build.gradle
, j'avais quelque chose comme ceci pour appeler la commande ndk build.
commandLine 'ndk-build', '-C', file('src/main/jni').absolutePath
Je le change en
commandLine '/home/user/bin/Android_ndk/Android-ndk-r10e/ndk-build', '-C', file('src/main/jni').absolutePath
J'ai donné le chemin complet de la construction de NDK. J'espère que ça vous aidera.
essaye ça
commandLine'E:\\Android\\ndk\\ndkbuild.cmd','-C',file('src/main/jni').absolutePath
remplacez (E: \\ Android \\ ndk \\) par votre chemin ndk.
Dans Android studio, Fichier-> Structure du projet -> Emplacement du SDK, Définissez l’emplacement du NDK Android pour votre ordinateur.
Merci!
Juste au cas où cela aiderait quelqu'un d'autre:
Donner le chemin NDK (dossier parent où réside ndkBuild.cmd) dans les variables d'environnement résout également le problème.
Vous pouvez également suivre la réponse de @Hayk si vous utilisez Linux ou la réponse de @Nooh pour Windows.
Mon observation:
Comme, si je mettais directement le chemin NDK, mon problème dans Android Studio était parfois résolu, mais encore une fois, il échouait à générer et jeta une erreur, puis je plaçais le chemin dans Variables d'environnement et le projet était construit avec succès.
Dans ce cas, pour Windows, il faut mettre *
* et pour l'environnement Linux uniquement *
*
Tout d’abord, vous devez vérifier le fichier local.properties dans votre projet. Dans local.properties, vérifiez le chemin ndk. Cela ressemble à ceci ndk.dir = D: \\ sdk \\ ndk-bundle.
Maintenant, allez dans le build.gradle (bibliothèque du module) et trouvez getNdkPath (). Il renverra l’emplacement du chemin ndk qui concatnera le ndk-build
Modifiez ndk-build -> ndk-build.cmd. Cela ressemble à ceci:
J'espère que cela vous aidera!
Ajoutez le chemin ndk (C:\Android-ndk-r10e) à la valeur de la variable path dans la variable d'environnement (variable système) qui a laissé ma variable "path" comme celle-ci.
Paramètres -> Système -> Paramètres système avancés -> Variables système
Ouvrez ensuite la fenêtre de commande (cmd). Entrez l'emplacement de votre dossier de projet avec les commandes cd et écrivez "ndk-build" puis appuyez sur entrée.
La réponse acceptée est OK, mais cela ne fonctionne pas car Android tools gradle plugin 2.3: Aucun champ sdkHandler dans LibraryPlugin après la mise à jour pour générer les outils 2.3.0 , vous devez donc utiliser la variable project.Android.ndkDirectory.absolutePath
alors, c'est-à-dire:
task ndkBuild(type: Exec) {
commandLine project.Android.ndkDirectory.absolutePath + '/ndk-build', '-C', file('src/main/jni/').absolutePath
}
Sinon, vous pouvez lire ndk.dir directement à partir de local.properties: https://stackoverflow.com/a/32649204/1028256