Skip to content
This repository was archived by the owner on Feb 22, 2023. It is now read-only.
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
39 commits
Select commit Hold shift + click to select a range
c3f703e
Start of Android side of byte stream passing
bparrishMines Oct 24, 2018
f310580
dart side of byte streaming
bparrishMines Oct 25, 2018
87fdb60
Fix android streaming
bparrishMines Oct 25, 2018
673b003
Merge branch 'master' of github.com:flutter/plugins into camera_android
bparrishMines Nov 14, 2018
8d353ad
Add ios byte streaming
bparrishMines Nov 15, 2018
0291a29
Convert buffer to uiimage to pass over
bparrishMines Nov 16, 2018
31f746a
formatting
bparrishMines Nov 18, 2018
5fcfeb2
Stream yuv bytes instead
bparrishMines Nov 28, 2018
040d1ae
Make video format a constant
bparrishMines Nov 29, 2018
16d1d32
Pass back metadata for ios image
bparrishMines Nov 29, 2018
8e88978
Pass back metadata for android image
bparrishMines Nov 29, 2018
67f8304
Dart code now parses camera image buffer
bparrishMines Nov 30, 2018
646283a
YUV image to bgra
bparrishMines Nov 30, 2018
7e99691
Add documentation
bparrishMines Dec 6, 2018
4cbfab9
Only pass available data on Android
bparrishMines Dec 6, 2018
aa0e263
Merge branch 'master' of github.com:bparrishMines/plugins into camera…
bparrishMines Dec 6, 2018
9b2ae22
Merge branch 'master' of github.com:flutter/plugins into camera_andro…
bparrishMines Dec 6, 2018
297fe7a
Bump version
bparrishMines Dec 6, 2018
bdd9007
Formatting
bparrishMines Dec 6, 2018
ccc057b
create imageformat error
bparrishMines Dec 7, 2018
989edf6
Don't return from null
bparrishMines Dec 7, 2018
22ce601
Merge branch 'master' of github.com:bparrishMines/plugins into camera…
bparrishMines Dec 10, 2018
b1d7b89
Init buffers in constructor
bparrishMines Dec 10, 2018
aa3db0c
Add yuv ios format
bparrishMines Dec 11, 2018
0349ae2
Used presets with defined resolution. Sometimes resolution would come…
bparrishMines Dec 11, 2018
2633c49
Formatting
bparrishMines Dec 13, 2018
6377c64
Move CameraImage classes to separate file
bparrishMines Dec 13, 2018
6660a68
Move camera.dart to src folder
bparrishMines Dec 13, 2018
a4d278e
Create camera library
bparrishMines Dec 13, 2018
045dd53
Better name and comments
bparrishMines Dec 19, 2018
01520fe
Change from library camera file
bparrishMines Dec 19, 2018
6155620
bytestream -> imagestream
bparrishMines Dec 19, 2018
5898b4c
Comments and names
bparrishMines Dec 20, 2018
7617bb9
Formatting
bparrishMines Dec 20, 2018
f18db98
Added resolution and fps todo
bparrishMines Dec 20, 2018
0bf466a
Unmodify file
bparrishMines Dec 20, 2018
a53222b
Empty commit to rerun tests
bparrishMines Dec 20, 2018
fe965d1
Remove TODO from documentation
bparrishMines Dec 20, 2018
7c0228f
Merge branch 'master' of github.com:flutter/plugins into camera_andro…
bparrishMines Jan 3, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
bytestream -> imagestream
  • Loading branch information
bparrishMines committed Dec 20, 2018
commit 615562056e0cebc9eb022b98344cc7f5cce187dd
Original file line number Diff line number Diff line change
Expand Up @@ -213,17 +213,17 @@ public void onMethodCall(MethodCall call, final Result result) {
camera.stopVideoRecording(result);
break;
}
case "startByteStream":
case "startImageStream":
{
try {
camera.startPreviewWithByteStream();
camera.startPreviewWithImageStream();
result.success(null);
} catch (CameraAccessException e) {
result.error("CameraAccess", e.getMessage(), null);
}
break;
}
case "stopByteStream":
case "stopImageStream":
{
try {
camera.startPreview();
Expand Down Expand Up @@ -754,7 +754,7 @@ public void onConfigureFailed(@NonNull CameraCaptureSession cameraCaptureSession
null);
}

private void startPreviewWithByteStream() throws CameraAccessException {
private void startPreviewWithImageStream() throws CameraAccessException {
closeCaptureSession();

SurfaceTexture surfaceTexture = textureEntry.surfaceTexture();
Expand Down Expand Up @@ -793,23 +793,23 @@ public void onConfigured(@NonNull CameraCaptureSession session) {

@Override
public void onConfigureFailed(@NonNull CameraCaptureSession cameraCaptureSession) {
sendErrorEvent("Failed to configure the camera for streaming bytes.");
sendErrorEvent("Failed to configure the camera for streaming images.");
}
},
null);

registerByteStreamEventChannel();
registerImageStreamEventChannel();
}

private void registerByteStreamEventChannel() {
private void registerImageStreamEventChannel() {
final EventChannel cameraChannel =
new EventChannel(registrar.messenger(), "plugins.flutter.io/camera/bytes");
new EventChannel(registrar.messenger(), "plugins.flutter.io/camera/imageStream");

cameraChannel.setStreamHandler(
new EventChannel.StreamHandler() {
@Override
public void onListen(Object o, EventChannel.EventSink eventSink) {
setByteStreamImageAvailableListener(eventSink);
setImageStreamImageAvailableListener(eventSink);
}

@Override
Expand All @@ -819,7 +819,7 @@ public void onCancel(Object o) {
});
}

private void setByteStreamImageAvailableListener(final EventChannel.EventSink eventSink) {
private void setImageStreamImageAvailableListener(final EventChannel.EventSink eventSink) {
imageStreamReader.setOnImageAvailableListener(
new ImageReader.OnImageAvailableListener() {
@Override
Expand Down
50 changes: 25 additions & 25 deletions packages/camera/ios/Classes/CameraPlugin.m
Original file line number Diff line number Diff line change
Expand Up @@ -22,11 +22,11 @@ @interface FLTSavePhotoDelegate : NSObject <AVCapturePhotoCaptureDelegate>
- initWithPath:(NSString *)filename result:(FlutterResult)result;
@end

@interface FLTByteStreamHandler : NSObject <FlutterStreamHandler>
@interface FLTImageStreamHandler : NSObject <FlutterStreamHandler>
@property FlutterEventSink eventSink;
@end

@implementation FLTByteStreamHandler
@implementation FLTImageStreamHandler

- (FlutterError *_Nullable)onCancelWithArguments:(id _Nullable)arguments {
_eventSink = nil;
Expand Down Expand Up @@ -85,7 +85,7 @@ @interface FLTCam : NSObject <FlutterTexture,
@property(readonly, nonatomic) int64_t textureId;
@property(nonatomic, copy) void (^onFrameAvailable)();
@property(nonatomic) FlutterEventChannel *eventChannel;
@property(nonatomic) FLTByteStreamHandler *byteStreamHandler;
@property(nonatomic) FLTImageStreamHandler *imageStreamHandler;
@property(nonatomic) FlutterEventSink eventSink;
@property(readonly, nonatomic) AVCaptureSession *captureSession;
@property(readonly, nonatomic) AVCaptureDevice *captureDevice;
Expand All @@ -103,7 +103,7 @@ @interface FLTCam : NSObject <FlutterTexture,
@property(strong, nonatomic) AVCaptureAudioDataOutput *audioOutput;
@property(assign, nonatomic) BOOL isRecording;
@property(assign, nonatomic) BOOL isAudioSetup;
@property(assign, nonatomic) BOOL isStreamingBytes;
@property(assign, nonatomic) BOOL isStreamingImages;
@property(nonatomic) vImage_Buffer destinationBuffer;
@property(nonatomic) vImage_Buffer conversionBuffer;
- (instancetype)initWithCameraName:(NSString *)cameraName
Expand All @@ -114,8 +114,8 @@ - (void)start;
- (void)stop;
- (void)startVideoRecordingAtPath:(NSString *)path result:(FlutterResult)result;
- (void)stopVideoRecordingWithResult:(FlutterResult)result;
- (void)startByteStreamWithMessenger:(NSObject<FlutterBinaryMessenger> *)messenger;
- (void)stopByteStream;
- (void)startImageStreamWithMessenger:(NSObject<FlutterBinaryMessenger> *)messenger;
- (void)stopImageStream;
- (void)captureToFile:(NSString *)filename result:(FlutterResult)result;
@end

Expand Down Expand Up @@ -220,8 +220,8 @@ - (void)captureOutput:(AVCaptureOutput *)output
});
return;
}
if (_isStreamingBytes) {
if (_byteStreamHandler.eventSink) {
if (_isStreamingImages) {
if (_imageStreamHandler.eventSink) {
CVPixelBufferRef pixelBuffer = CMSampleBufferGetImageBuffer(sampleBuffer);
CVPixelBufferLockBaseAddress(pixelBuffer, kCVPixelBufferLock_ReadOnly);

Expand Down Expand Up @@ -255,7 +255,7 @@ - (void)captureOutput:(AVCaptureOutput *)output
imageBuffer[@"format"] = @(videoFormat);
imageBuffer[@"planes"] = planes;

_byteStreamHandler.eventSink(imageBuffer);
_imageStreamHandler.eventSink(imageBuffer);

CVPixelBufferUnlockBaseAddress(pixelBuffer, kCVPixelBufferLock_ReadOnly);
}
Expand Down Expand Up @@ -448,29 +448,29 @@ - (void)stopVideoRecordingWithResult:(FlutterResult)result {
}
}

- (void)startByteStreamWithMessenger:(NSObject<FlutterBinaryMessenger> *)messenger {
if (!_isStreamingBytes) {
- (void)startImageStreamWithMessenger:(NSObject<FlutterBinaryMessenger> *)messenger {
if (!_isStreamingImages) {
FlutterEventChannel *eventChannel =
[FlutterEventChannel eventChannelWithName:@"plugins.flutter.io/camera/bytes"
[FlutterEventChannel eventChannelWithName:@"plugins.flutter.io/camera/imageStream"
binaryMessenger:messenger];

_byteStreamHandler = [[FLTByteStreamHandler alloc] init];
[eventChannel setStreamHandler:_byteStreamHandler];
_imageStreamHandler = [[FLTImageStreamHandler alloc] init];
[eventChannel setStreamHandler:_imageStreamHandler];

_isStreamingBytes = YES;
_isStreamingImages = YES;
} else {
_eventSink(
@{@"event" : @"error", @"errorDescription" : @"Bytes from camera are already streaming!"});
@{@"event" : @"error", @"errorDescription" : @"Images from camera are already streaming!"});
}
}

- (void)stopByteStream {
if (_isStreamingBytes) {
_isStreamingBytes = NO;
_byteStreamHandler = nil;
- (void)stopImageStream {
if (_isStreamingImages) {
_isStreamingImages = NO;
_imageStreamHandler = nil;
} else {
_eventSink(
@{@"event" : @"error", @"errorDescription" : @"Bytes from camera are not streaming!"});
@{@"event" : @"error", @"errorDescription" : @"Images from camera are not streaming!"});
}
}

Expand Down Expand Up @@ -648,11 +648,11 @@ - (void)handleMethodCall:(FlutterMethodCall *)call result:(FlutterResult)result
});
[cam start];
}
} else if ([@"startByteStream" isEqualToString:call.method]) {
[_camera startByteStreamWithMessenger:_messenger];
} else if ([@"startImageStream" isEqualToString:call.method]) {
[_camera startImageStreamWithMessenger:_messenger];
result(nil);
} else if ([@"stopByteStream" isEqualToString:call.method]) {
[_camera stopByteStream];
} else if ([@"stopImageStream" isEqualToString:call.method]) {
[_camera stopImageStream];
result(nil);
} else {
NSDictionary *argsMap = call.arguments;
Expand Down
Loading