From 155c1cbce3a6b1113b31101988fea92d8ebeee78 Mon Sep 17 00:00:00 2001 From: HUI Date: Tue, 15 Dec 2020 23:53:02 +0800 Subject: [PATCH] feat: example support `switchRender` fix: `RtcSurfaceView` memory leak #309 --- example/ios/AgoraExample/Info.plist | 4 ++ .../src/examples/basic/JoinChannelVideo.tsx | 46 ++++++++++++++----- .../React/RCTAgoraRtcSurfaceViewManager.swift | 19 +++++++- 3 files changed, 56 insertions(+), 13 deletions(-) diff --git a/example/ios/AgoraExample/Info.plist b/example/ios/AgoraExample/Info.plist index 41790beb9..7361dfb89 100644 --- a/example/ios/AgoraExample/Info.plist +++ b/example/ios/AgoraExample/Info.plist @@ -37,8 +37,12 @@ + NSCameraUsageDescription + Camera NSLocationWhenInUseUsageDescription + NSMicrophoneUsageDescription + Microphone UILaunchStoryboardName LaunchScreen UIRequiredDeviceCapabilities diff --git a/example/src/examples/basic/JoinChannelVideo.tsx b/example/src/examples/basic/JoinChannelVideo.tsx index b045dd917..d3af02635 100644 --- a/example/src/examples/basic/JoinChannelVideo.tsx +++ b/example/src/examples/basic/JoinChannelVideo.tsx @@ -1,18 +1,19 @@ import React, { Component } from 'react'; import { - View, - TextInput, - PermissionsAndroid, - StyleSheet, Button, + PermissionsAndroid, Platform, + StyleSheet, + TextInput, + TouchableOpacity, + View, } from 'react-native'; import RtcEngine, { - RtcLocalView, - RtcRemoteView, ChannelProfile, ClientRole, + RtcLocalView, + RtcRemoteView, } from 'react-native-agora'; const config = require('../../../agora.config.json'); @@ -22,6 +23,7 @@ interface State { isJoined: boolean; remoteUid: number | undefined; switchCamera: boolean; + switchRender: boolean; } export default class JoinChannelAudio extends Component<{}, State, any> { @@ -33,7 +35,8 @@ export default class JoinChannelAudio extends Component<{}, State, any> { channelId: config.channelId, isJoined: false, remoteUid: undefined, - switchCamera: false, + switchCamera: true, + switchRender: true, }; } @@ -107,6 +110,11 @@ export default class JoinChannelAudio extends Component<{}, State, any> { }); }; + _switchRender = () => { + const { switchRender } = this.state; + this.setState({ switchRender: !switchRender }); + }; + render() { const { channelId, isJoined, switchCamera } = this.state; return ( @@ -135,17 +143,31 @@ export default class JoinChannelAudio extends Component<{}, State, any> { } _renderVideo = () => { - const { remoteUid } = this.state; + const { remoteUid, switchRender } = this.state; return ( - - {remoteUid !== undefined && ( + {switchRender ? ( + + ) : ( )} + {remoteUid !== undefined && ( + + {switchRender ? ( + + ) : ( + + )} + + )} ); }; diff --git a/ios/RCTAgora/React/RCTAgoraRtcSurfaceViewManager.swift b/ios/RCTAgora/React/RCTAgoraRtcSurfaceViewManager.swift index 3a9c5bf69..66dd93179 100644 --- a/ios/RCTAgora/React/RCTAgoraRtcSurfaceViewManager.swift +++ b/ios/RCTAgora/React/RCTAgoraRtcSurfaceViewManager.swift @@ -9,6 +9,22 @@ import Foundation import AgoraRtcKit +fileprivate struct AssociatedKeys { + static var view: UInt8 = 0 +} + +@objc(AgoraRtcVideoCanvas) +public extension AgoraRtcVideoCanvas { + @objc weak var view: UIView? { + get { + return objc_getAssociatedObject(self, &AssociatedKeys.view) as? UIView + } + set { + objc_setAssociatedObject(self, &AssociatedKeys.view, newValue, .OBJC_ASSOCIATION_ASSIGN) + } + } +} + @objc(RCTAgoraRtcSurfaceViewManager) class RCTAgoraRtcSurfaceViewManager: RCTViewManager { override func view() -> UIView! { @@ -39,8 +55,9 @@ class RCTAgoraRtcSurfaceViewManager: RCTViewManager { class RtcView: RtcSurfaceView { private var getEngine: (() -> AgoraRtcEngineKit?)? private var getChannel: ((_ channelId: String) -> AgoraRtcChannel?)? - + deinit { + destroy() // if let engine = getEngine?() { // resetVideoCanvas(engine) // }