从Objective-C获取对react-native创建的图像视图的引用

时间:2016-08-09 23:28:32

标签: ios imageview react-native uiview-hierarchy

如何从Objective-C获取对react-native创建的一个图像视图的引用。

我有一个基本的反应本机应用程序,我使用以下js代码

创建
import React, { Component } from 'react';
import {
  AppRegistry,
  StyleSheet,
  Text,
  View,
  Image
} from 'react-native';

import { NativeModules } from 'react-native';
var FaceSdkNativeBridge = NativeModules.ViewController;
FaceSdkNativeBridge.init('msg');

// class ReactFaceSdk extends Component {
var ReactFaceSdk = React.createClass({
  render() {
    return (
      <View style={styles.container}>
        <Text style={styles.welcome}>
          Welcome to React Native! Welcome to React Native!
        </Text>
        <Text style={styles.instructions}>
          To get started, edit index.ios.js
        </Text>
        <Text style={styles.instructions}>
          Press Cmd+R to reload,{'\n'}
          Cmd+D or shake for dev menu
        </Text>
        <Image
          style={[styles.cameraFeedImage, this.border('green')]}
          source={{uri: 'https://facebook.github.io/react/img/logo_og.png'}}>
        </Image>
      </View>
    );
  },
  border: function(color) {
    return {
      borderColor: color,
      borderWidth: 4
    }
  }
});
// }

const styles = StyleSheet.create({
  container: {
    flex: 1,
    justifyContent: 'center',
    alignItems: 'center',
    backgroundColor: '#F5FCFF',
  },
  welcome: {
    fontSize: 20,
    textAlign: 'center',
    margin: 10,
  },
  instructions: {
    textAlign: 'center',
    color: '#333333',
    marginBottom: 5,
  },
  cameraFeedImage: {
    justifyContent: 'center',
    alignItems: 'center',
    backgroundColor: '#F5FCFF',
    width: 350,
    height: 350
  }
});

AppRegistry.registerComponent('ReactFaceSdk', () => ReactFaceSdk);

我想从Objective-c端访问该组件(RCTImageView)。我怎么能得到它的参考?

这就是我的AppDelegate.m的样子

RCTRootView *rootView = [[RCTRootView alloc] initWithBundleURL:jsCodeLocation
                                                      moduleName:@"ReactFaceSdk"
                                               initialProperties:nil
                                                   launchOptions:launchOptions];
  rootView.backgroundColor = [[UIColor alloc] initWithRed:1.0f green:1.0f blue:1.0f alpha:0.5f];    
  self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];
  UIViewController *rootViewController = [UIViewController new];
  rootViewController.view = rootView;
  self.window.rootViewController = rootViewController;
  [self.window makeKeyAndVisible];

p.s:视图层次结构的参考 enter image description here

0 个答案:

没有答案