web-dev-qa-db-ja.com

NDKBuildの失敗

NDKをAndroid Studioで正しくコンパイルするのに問題があります。コンパイルするために実行しようとすると、次のエラーが表示されます。

エラー:タスク ':app:ndkBuild'の実行に失敗しました。プロセス 'command' ndk-build.cmd ''の起動中に問題が発生しました

私は次のセットアップを持っています

enter image description here

そして、私のbuild.gradleファイルは次のとおりです。

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')
}

この時点で、何が間違っているのか迷っています。いくつかのチュートリアルに従ってNDKを適切に設定してみましたが、上記のエラーが引き続き発生します。 NDKをコンパイルするために必要なことについて、ここの誰かがフィードバックを提供できますか?

編集:ここに発生するメッセージ全体です。

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
24
Valrok

この種の問題に出会いました。まず、アプリのlocal.propertiesでNDKパスを指定する必要があります。

例えばndk.dir=/home/user/bin/Android_ndk/Android-ndk-r10e

次に、build.gradleファイルに、ndk buildコマンドを呼び出すためのこのようなものがありました。

commandLine 'ndk-build', '-C', file('src/main/jni').absolutePath

変更する

commandLine '/home/user/bin/Android_ndk/Android-ndk-r10e/ndk-build', '-C', file('src/main/jni').absolutePath

NDKビルドの完全なパスを指定しました。それがあなたを助けることを願っています。

49
Hayk Nahapetyan

これを試して

commandLine'E:\\Android\\ndk\\ndkbuild.cmd','-C',file('src/main/jni').absolutePath

(E:\\ Android \\ ndk \\)をndkパスに置き換えます。

8
Nooh

Android studio、File-> Project Structure-> SDK Location、Set the Android NDK location for your computer。

ありがとう!

8
jungwook

それが他の誰かを助ける場合に備えて:

環境変数にNDKパス(ndkBuild.cmdが存在する親フォルダー)を指定すると、問題も解決します。

あるいは、Linuxの場合は@Haykの回答、Windowsの場合は@Noohの回答に従うことができます。

私の観察:

として、直接NDKパスを置くと、Android Studioで問題が解決することがありましたが、ビルドに失敗し、エラーがスローされ、環境変数にパスを入れて、プロジェクトを正常にビルドしました。

その場合、Windowsの場合は*を入力する必要があります

  • ndk-build.cmd

*およびLinux環境のみ*

  • ndk-build

*

4
abhy

Android studio 2.3.3。File-> Project Structure-> Android NDK Location-> Click download button。をクリックしてください。問題 enter image description here

4
Tariqul
  1. まず、プロジェクトのlocal.propertiesファイルを確認する必要があります。 local.propertiesで、ndkパスを確認します。このように見えますndk.dir = D:\\ sdk \\ ndk-bundle

  2. 次に、build.gradle(Module library)に移動して、getNdkPath()を見つけます。 ndk-buildを連結するndkパスの場所を返します

  3. 変更ndk-build->ndk-build.cmd次のようになります。

    enter image description here

それがあなたを助けることを願っています!

2
Jatinder Kumar

Ndkパス(C:\ Android-ndk-r10e)を環境変数(システム変数)のパス変数の値に追加して、このように「パス」変数を​​残しました

設定->システム->高度なシステム設定->システム変数 enter image description here


コマンドウィンドウ(cmd)を開きます。 cdコマンドを使用してプロジェクトフォルダーの場所を入力し、「ndk-build」と入力してEnterキーを押します。

2
Fatih Çengel

受け入れられた答えはOKですが、Android tools gradle plugin 2.3: ビルドツール2.3.0に更新した後、LibraryPluginにsdkHandlerフィールドがない なので、機能しません。 project.Android.ndkDirectory.absolutePath変数を使用する必要があります。つまり:

task ndkBuild(type: Exec) {
    commandLine project.Android.ndkDirectory.absolutePath + '/ndk-build', '-C', file('src/main/jni/').absolutePath
}

または、local.propertiesからndk.dirを直接読み取ることもできます。 https://stackoverflow.com/a/32649204/1028256

0
Mixaz