Android Studio初始化Vuforia失败

3

[已解决-请看下面的答案]


我是移动开发新手,目前正在Android Studio项目上工作,需要一些依赖项才能运行基于专有游戏引擎开发的VR模拟器。不久前,这个游戏引擎的公司在Eclipse上创建了一个Android应用程序,该应用程序可以运行他们的模拟器。我正在尝试将我需要的库和类导入我的项目中,但遇到了许多问题。我花了相当多的时间来解决其中的一个问题,涉及Vuforia。

Error - failed to assert required Android permissions. Failed to initialize QCAR SDK. All required Android permissions must be included for the SDK to work.  
InitVuforiaTask.onPostExecute: Failed to initialize Vuforia. Exiting.  
EGLint new_window_surface(egl_winsys_display*, void*, EGLSurface, EGLConfig, egl_winsys_surface**, egl_color_buffer_format*, EGLBoolean) returns 0x3000,  [2560x1440]-format:1  
STS_GLApi : DTS is not allowed for Package : com.company.myproject

我的.so库从src/main/jniLibs文件夹加载,我的.jar库从src/main/libs文件夹加载。
我使用的Eclipse项目针对Android API 19,最小sdk版本为15。在Android Studio(2.3.1)中导入后,在我的测试设备上运行。
我的清单文件中包含的权限:
<uses-feature android:glEsVersion="0x00020000" android:required="true" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-feature android:name="android.hardware.camera" />
<uses-permission android:name="android.permission.CAMERA" />

我尝试添加:

<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
<uses-feature android:name="android.hardware.camera.autofocus" />

...但是它并没有改变任何东西。 这是我的应用Gradle:

`apply plugin: 'com.android.application'
    android {
    compileSdkVersion 25
    buildToolsVersion "25.0.2"
    defaultConfig {
        applicationId "com.mycompany.myproject"
        minSdkVersion 15
        targetSdkVersion 25
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    compile fileTree(include: ['*.jar'], dir: 'libs')
    androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {
        exclude group: 'com.android.support', module: 'support-annotations'
    })
    compile 'com.android.support:appcompat-v7:25.3.0'
    compile 'com.android.support.constraint:constraint-layout:1.0.2'
    compile 'com.android.support:design:25.3.0'
    compile 'com.android.support:recyclerview-v7:25.3.0'
    testCompile 'junit:junit:4.12'
    compile files('src/main/libs/BT200Ctrl.jar')
    compile files('src/main/libs/NativeMediaPlayer.jar')
    compile files('src/main/libs/Net.jar')
    compile files('src/main/libs/Sensors.jar')
    compile files('src/main/libs/VoIP.jar')
    compile files('src/main/libs/portsipvoipsdk.jar')
    compile files('src/main/libs/Vuforia.jar')
}

有人可以帮我解决这个问题吗?


回答

Kevin Sanchez的答案解决了我的问题。

在使用Vuforia启动活动之前,我们需要明确要求相机权限(这是新API版本的要求)。

我插入了以下语句来代替直接使用 Vuforia 启动 Activity:

if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.CAMERA) != PackageManager.PERMISSION_GRANTED) {
    ActivityCompat.requestPermissions(MainActivity.this, new String[]{Manifest.permission.CAMERA, Manifest.permission.WRITE_EXTERNAL_STORAGE}, 0);
} else {
    Intent intent = new Intent(MainActivity.this, VuforiaActivity.class);
    startActivity(intent);
}

在申请相机权限的活动中,我们需要监听用户的回答:
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
    super.onRequestPermissionsResult(requestCode, permissions, grantResults);

    if (requestCode == 0) {
        if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
            Intent intent = new Intent(MainActivity.this, VuforiaActivity.class);
            startActivity(intent);
        } else {
            Toast.makeText(getApplicationContext(), getString(R.string.error_permission_needed), Toast.LENGTH_LONG).show();
        }
    }
}

你可以在这个问题的答案中查看 http://stackoverflow.com/a/43480446/5335153 - Kevin Sanchez
成功了,谢谢!我只是从 if 语句里面去掉了 "grantResults [1]" 才使我的代码起作用 :) - Lilamuse
1个回答

0

这个错误发生的原因有2到3个:

  • SDK缺失
  • 许可证密钥丢失
  • gradle文件没有更新以从应用程序中的libs文件夹加载SDK

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接