【问题标题】:Does react-native-video work with react-native-navigationreact-native-video 是否与 react-native-navigation 一起使用
【发布时间】:2017-07-17 13:54:03
【问题描述】:

我正在尝试在我的 react 本机应用中播放视频。 I'm trying to use react-native-video 但是当通过react-native run-android 运行应用程序时,我收到错误消息:

"undefined 不是对象(评估'_reactNative.NativeModules.UIManager.RCT Video.Constants')

这条消息并没有真正告诉我太多,但在尝试让它工作一段时间后,我开始怀疑 react-native-navigation, 是我用于我的应用程序的导航,与它有关.所以我创建了一个新的 react-native 项目并添加了 react-native-video 并让它运行起来没有太多麻烦。

所以我的问题是,是否有人遇到过同样的事情,并且可以提供一个解决方案来让这两个包一起工作?

我的 settings.gradle:

rootProject.name = 'newproj'
include ':react-native-video'
project(':react-native-video').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-video/android')

include ':app'
include ':react-native-navigation'
project(':react-native-navigation').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-navigation/android/app/')

build.gradle 模块 react-native-video

apply plugin: 'com.android.library'

android {
    compileSdkVersion 23
    buildToolsVersion '25.0.1'

    defaultConfig {
        minSdkVersion 16
        targetSdkVersion 22
        versionCode 1
        versionName "1.0"
        ndk {
            abiFilters "armeabi-v7a", "x86"
        }
    }
}

dependencies {
    provided 'com.facebook.react:react-native:+'
    compile 'com.yqritc:android-scalablevideoview:1.0.1'
}

build.grade 模块中的依赖项:app

dependencies {
    compile fileTree(dir: "libs", include: ["*.jar"])
    compile "com.android.support:appcompat-v7:23.0.1"
    compile "com.facebook.react:react-native:+"  // From node_modules
    compile project(':react-native-navigation')
    compile project(':react-native-video')
}

MainApplication.java

import android.app.Application;

import com.facebook.react.ReactApplication;
import com.brentvatne.react.ReactVideoPackage;
import com.facebook.react.ReactNativeHost;
import com.facebook.react.ReactPackage;
import com.facebook.react.shell.MainReactPackage;
import com.facebook.soloader.SoLoader;
import com.reactnativenavigation.NavigationApplication;

import java.util.Arrays;
import java.util.List;

public class MainApplication extends NavigationApplication {

  private final ReactNativeHost mReactNativeHost = new ReactNativeHost(this) {
    @Override
    public boolean getUseDeveloperSupport() {
      return BuildConfig.DEBUG;
    }

    @Override
    protected List<ReactPackage> getPackages() {
      return Arrays.<ReactPackage>asList(
          new MainReactPackage(),
            new ReactVideoPackage()
      );
    }
  };

  @Override
  public ReactNativeHost getReactNativeHost() {
    return mReactNativeHost;
  }

  @Override
  public void onCreate() {
    super.onCreate();
    SoLoader.init(this, /* native exopackage */ false);
  }

    @Override
    public boolean isDebug() {
        // Make sure you are using BuildConfig from your own application
        return BuildConfig.DEBUG;
    }

    @Override
    public List<ReactPackage> createAdditionalReactPackages() {
        return null;
    }

}

在我的 react native 项目中:

import Video from 'react-native-video';

  <View style={styles.container}>
        <Video source={{uri: "youtube.com"}}  
          ref={(ref) => {
            this.player = ref
          }}   
resizeMode="cover"  
style={styles.backgroundVideo} 
/>
</View>

【问题讨论】:

  • 你能用你的代码更新你的帖子吗?
  • 不确定它如何帮助解决这个特殊问题,但我现在已经更新了代码!
  • react-navigationreact-native-video 之间没有联系,undefined is not an object 通常发生在您忘记声明参数时。因此,如果您发布该特定屏幕的完整代码(js 代码而不是 java 代码)会很有帮助

标签: android video react-native react-native-navigation


【解决方案1】:

createAdditionalReactPackages 应该退回包裹。

改变这个

@Override
public List<ReactPackage> createAdditionalReactPackages() {
    return null;
}

到这里:

@Override
public List<ReactPackage> createAdditionalReactPackages() {
    return getPackages();
}

【讨论】:

    猜你喜欢
    • 2017-10-11
    • 2017-10-24
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2022-10-25
    • 1970-01-01
    • 2017-11-28
    • 1970-01-01
    相关资源
    最近更新 更多