Index: webrtc/sdk/objc/Framework/Classes/Metal/RTCMTLNSVideoView.m |
diff --git a/webrtc/sdk/objc/Framework/Classes/Metal/RTCMTLNSVideoView.m b/webrtc/sdk/objc/Framework/Classes/Metal/RTCMTLNSVideoView.m |
new file mode 100644 |
index 0000000000000000000000000000000000000000..2b3682fe84d6aa06376a260ac232a57ceab04d45 |
--- /dev/null |
+++ b/webrtc/sdk/objc/Framework/Classes/Metal/RTCMTLNSVideoView.m |
@@ -0,0 +1,114 @@ |
+/* |
+ * Copyright 2017 The WebRTC project authors. All Rights Reserved. |
+ * |
+ * Use of this source code is governed by a BSD-style license |
+ * that can be found in the LICENSE file in the root of the source |
+ * tree. An additional intellectual property rights grant can be found |
+ * in the file PATENTS. All contributing project authors may |
+ * be found in the AUTHORS file in the root of the source tree. |
+ */ |
+ |
+#import "WebRTC/RTCMTLNSVideoView.h" |
+ |
+#import <Metal/Metal.h> |
+#import <MetalKit/MetalKit.h> |
+ |
+#import "WebRTC/RTCVideoFrame.h" |
+ |
+#import "RTCMTLI420Renderer.h" |
+ |
+@interface RTCMTLNSVideoView () <MTKViewDelegate> |
+@property(nonatomic) id<RTCMTLRenderer> renderer; |
+@property(nonatomic, strong) MTKView *metalView; |
+@property(atomic, strong) RTCVideoFrame *videoFrame; |
+@end |
+ |
+@implementation RTCMTLNSVideoView { |
+ id<RTCMTLRenderer> _renderer; |
+} |
+ |
+@synthesize renderer = _renderer; |
+@synthesize metalView = _metalView; |
+@synthesize videoFrame = _videoFrame; |
+ |
+- (instancetype)initWithFrame:(CGRect)frameRect { |
+ self = [super initWithFrame:frameRect]; |
+ if (self) { |
+ [self configure]; |
+ } |
+ return self; |
+} |
+ |
+- (instancetype)initWithCoder:(NSCoder *)aCoder { |
+ self = [super initWithCoder:aCoder]; |
+ if (self) { |
+ [self configure]; |
+ } |
+ return self; |
+} |
+ |
+#pragma mark - Private |
+ |
++ (BOOL)isMetalAvailable { |
+ return YES; |
+} |
+ |
+- (void)configure { |
+ if ([[self class] isMetalAvailable]) { |
+ _metalView = [[MTKView alloc] initWithFrame:self.bounds]; |
+ [self addSubview:_metalView]; |
+ _metalView.translatesAutoresizingMaskIntoConstraints = NO; |
+ _metalView.framebufferOnly = YES; |
+ _metalView.delegate = self; |
+ |
+ _renderer = [[RTCMTLI420Renderer alloc] init]; |
+ if (![(RTCMTLI420Renderer *)_renderer addRenderingDestination:_metalView]) { |
+ _renderer = nil; |
+ }; |
+ } |
+} |
+ |
+- (void)updateConstraints { |
+ NSDictionary *views = NSDictionaryOfVariableBindings(_metalView); |
+ |
+ NSArray *constraintsHorizontal = |
+ [NSLayoutConstraint constraintsWithVisualFormat:@"H:|-0-[_metalView]-0-|" |
+ options:0 |
+ metrics:nil |
+ views:views]; |
+ [self addConstraints:constraintsHorizontal]; |
+ |
+ NSArray *constraintsVertical = |
+ [NSLayoutConstraint constraintsWithVisualFormat:@"V:|-0-[_metalView]-0-|" |
+ options:0 |
+ metrics:nil |
+ views:views]; |
+ [self addConstraints:constraintsVertical]; |
+ [super updateConstraints]; |
+} |
+ |
+#pragma mark - MTKViewDelegate methods |
+- (void)drawInMTKView:(nonnull MTKView *)view { |
+ if (view == self.metalView) { |
+ [_renderer drawFrame:self.videoFrame]; |
+ } |
+} |
+ |
+- (void)mtkView:(MTKView *)view drawableSizeWillChange:(CGSize)size { |
+} |
+ |
+#pragma mark - RTCVideoRenderer |
+ |
+- (void)setSize:(CGSize)size { |
+ _metalView.drawableSize = size; |
+ [_metalView draw]; |
+} |
+ |
+- (void)renderFrame:(nullable RTCVideoFrame *)frame { |
+ if (frame == nil) { |
+ return; |
+ } |
+ self.videoFrame = [frame newI420VideoFrame]; |
magjed_webrtc
2017/03/28 11:20:29
We should look at frame.nativeHandle instead and d
daniela-webrtc
2017/03/28 14:58:05
Is it ok to fix this in upcoming CL when I do the
magjed_webrtc
2017/03/30 08:29:28
Yes, that's fine.
|
+} |
+ |
+@end |