【问题标题】:Error:Execution failed for task ':app:ndkBuild'错误:任务“:app:ndkBuild”执行失败
【发布时间】:2018-07-29 09:32:27
【问题描述】:

我使用 NDK 和 OpenCV 开发用于人体检测的应用程序。

出现这样的错误。 **错误:任务 ':app:ndkBuild' 执行失败。

启动进程'command'/home/android/Android/Sdk/ndk-bundle/ndk-build.cmd''时出现问题**

计算机操作系统:Ubuntu 12.04(64 位)。

Android studio 版本为:3.0.1

您能帮帮我吗。最近 2 天我正在尝试解决此错误。我在 google 中搜索过,但该解决方案无法解决此错误。

我试过这样:

MainActivity.java

public class MainActivity extends AppCompatActivity implements CameraBridgeViewBase.CvCameraViewListener2 {
public static final String TAG = "MainActivity";
JavaCameraView javaCameraView;
Mat mRgba,igray,iCanny;
BaseLoaderCallback mLoaderCallaBack = new BaseLoaderCallback(this) {
    @Override
    public void onManagerConnected(int status) {
        switch (status) {
            case BaseLoaderCallback.SUCCESS: {
                javaCameraView.enableView();
                break;

            }
            default: {
                super.onManagerConnected(status);
                break;
            }
        }
        super.onManagerConnected(status);
    }
};
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    javaCameraView =(JavaCameraView)findViewById(R.id.java_camera_view);
    javaCameraView.setVisibility(SurfaceView.VISIBLE);
    javaCameraView.setCvCameraViewListener(this);
}

@Override
protected void onPause(){
    super.onPause();
    if(javaCameraView!=null)
        javaCameraView.disableView();
}
protected void onDistroy(){
    super.onPause();
    if(javaCameraView!=null)
        javaCameraView.disableView();
}

protected void onResume(){
super.onResume();
        if(OpenCVLoader.initDebug()){
            Log.d(TAG,"SUCESSES");
            mLoaderCallaBack.onManagerConnected(LoaderCallbackInterface.SUCCESS);

        }else {
            Log.d(TAG,"FAIL");
            OpenCVLoader.initAsync(OpenCVLoader.OPENCV_VERSION_2_4_9,this,mLoaderCallaBack);
        }

}

@Override
public void onCameraViewStarted(int width, int height) {
    mRgba = new Mat(height,width, CvType.CV_8UC4);
    igray = new Mat(height,width, CvType.CV_8UC4);
}
@Override
public void onCameraViewStopped() {
    mRgba.release();
}
@Override
public Mat onCameraFrame(CameraBridgeViewBase.CvCameraViewFrame inputFrame) {
    mRgba = inputFrame.rgba();
    //NativeClass.faceDetection(mRgba.getNotificationObjAdde());
    //Imgproc.ctv

    return mRgba;
   }
 }

build.gradle:

应用插件:'com.android.application'

android {
   compileSdkVersion 26
   defaultConfig {
    applicationId "com.test.opencv"
    minSdkVersion 15
    targetSdkVersion 26
    versionCode 1
    versionName "1.0"

    testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
}
sourceSets.main {
    jni.srcDirs = [] //disable automatic ndk-build call
}
task ndkBuild(type: Exec, description: 'Compile JNI source via NDK') {
    commandLine '/home/android/Android/Sdk/ndk-bundle/ndk-build.cmd',
            'NDK_PROJECT_PATH=build/intermediates/ndk',
            'NDK_LIBS_OUT=src/main/jniLibs',
            'APP_BUILD_SCRIPT=src/main/jni/Android.mk',
            'NDK_APPLICATION_MK=src/main/jni/Application.mk'
}
tasks.withType(JavaCompile) {
    compileTask -> compileTask.dependsOn ndkBuild
}
buildTypes {
    release {
        minifyEnabled false
        proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
    }
}
sourceSets { main { jni.srcDirs = ['src/main/jni', 'src/main/jniLibs/'] } }

buildTypes{
}
}

dependencies {
implementation fileTree(include: ['*.jar'], dir: 'libs')
implementation 'com.android.support:appcompat-v7:26.1.0'
implementation 'com.android.support.constraint:constraint-layout:1.0.2'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'com.android.support.test:runner:1.0.1'
androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.1'
implementation project(':openCVLibrary249')
  }
 Android.mk
  LOCAL_PATH := $(call my-dir)
  include $(CLEAR_VARS)
  LOCAL_SRC_FILES := com_test_opencv_NativeClass.cpp
  LOCAL_LDLIBS += -llog
  LOCAL_MODULE := MyLibs
  include $(BUILD_SHARED_LIBRARY)

应用程序.mk

 APP_STL := gnustl_static
 APP_CPPFLAGS := -frtti -fexceptions
 APP_ABI := armeabi-v7a
 APP_PLATFORM := android-16
com_test_opencv_NativeClass.cpp:
  #include <com_test_opencv_NativeClass.h>
  JNIEXPORT void JNICALL    Java_com_test_opencv_NativeClass_humenDetection
  (JNIEnv *env, jclass,obj){
      return env->NewStringUTF("This is from JNI");
   }

com_test_opencv_NativeClass.h

 /* DO NOT EDIT THIS FILE - it is machine generated */
#include <jni.h>
 /* Header for class com_test_opencv_NativeClass */

 #ifndef _Included_com_test_opencv_NativeClass
 #define _Included_com_test_opencv_NativeClass
 #ifdef __cplusplus
 extern "C" {
 #endif

 JNIEXPORT void JNICALL Java_com_test_opencv_NativeClass_faceDetection
 (JNIEnv *, jclass, jlong);

 JNIEXPORT void JNICALL Java_com_test_opencv_NativeClass_humenDetection
  (JNIEnv *, jclass, jlong);

  #ifdef __cplusplus
  }
  #endif
  #endif

【问题讨论】:

    标签: android android-studio opencv android-ndk build.gradle


    【解决方案1】:

    您的 build.gradle 使用了旧模板,与 Android Studio 3 无关,而且您可能合并了两个相互矛盾的源。

    不过,直接的问题是您的 ndkBuild 是为 Windows 构建的,如果您只是删除 .cmd,您的脚本可能在 Ubuntu 上运行。但是让我们把它清理一下:

    apply plugin: 'com.android.application'
    
    android {
      compileSdkVersion 26
      defaultConfig {
        applicationId "com.test.opencv"
        minSdkVersion 15
        targetSdkVersion 26
        versionCode 1
        versionName "1.0"
    
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
        ndk {
          abiFilters 'armeabi-v7a'
        }
      }
    
      externalNativeBuild {
        ndkBuild {
          path "src/main/jni/Android.mk"
        }
      }
    
      buildTypes {
        release {
          minifyEnabled false
          proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
      }
    
      dependencies {
        implementation fileTree(include: ['*.jar'], dir: 'libs')
        implementation 'com.android.support:appcompat-v7:26.1.0'
        implementation 'com.android.support.constraint:constraint-layout:1.0.2'
        testImplementation 'junit:junit:4.12'
        androidTestImplementation 'com.android.support.test:runner:1.0.1'
        androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.1'
        implementation project(':openCVLibrary249')
      }
    }
    

    这假定:openCVLibrary249 配置正确。

    【讨论】:

    • 感谢您的回复。更改 build.prob 后出现此错误:未知类型名称 'obj' 错误:(5, 1) 错误:无效函数 'Java_com_test_opencv_NativeClass_humenDetection' 不应返回值 [- Wreturn-type] 错误:(4, 22) 错误: 未知类型名称 'obj' 错误:(5, 1) 错误: void function 'Java_com_test_opencv_NativeClass_humenDetection' 不应返回值 [-Wreturn-type]
    • 是的,文件com_test_opencv_NativeClass.cpp 已损坏。将jclass,obj 更改为jcalss, jlong
    • 感谢您的帮助。我是 NDK 的新手并打开 CV。我正在从您的视频中学习 NDK。我再次遇到另一个错误是..在添加 .mk 文件之前,它的工作条件将成功。现在它将失败条件......我在问题中添加了 MainActivity.java。
    • java.lang.RuntimeException:无法恢复活动 {com.test.opencv/com.test.opencv.MainActivity}:java.lang.IllegalArgumentException:服务意图必须明确:意图 { act= org.opencv.engine.BIND } 引起:java.lang.IllegalArgumentException:服务意图必须明确:com.test.opencv.MainActivity.onResume(MainActivity.java: 76)
    猜你喜欢
    • 2018-02-18
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-02-17
    • 2018-06-06
    • 2016-02-16
    相关资源
    最近更新 更多