Skip to content

Commit

Permalink
Fix for #1 Color issues.
Browse files Browse the repository at this point in the history
  • Loading branch information
vade committed Dec 12, 2014
1 parent 41fe8da commit e08de74
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 6 deletions.
1 change: 1 addition & 0 deletions v002 Media Tools/v002_Screen_CapturePlugIn.h
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
CGDisplayStreamRef displayStream;
dispatch_queue_t displayQueue;
IOSurfaceRef updatedSurface;
CGColorSpaceRef colorspaceForDisplayID;
}
// Ports
@property (assign) NSUInteger inputDisplayID;
Expand Down
33 changes: 27 additions & 6 deletions v002 Media Tools/v002_Screen_CapturePlugIn.m
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
@interface v002_Screen_CapturePlugIn (Private)
- (IOSurfaceRef)copyNewFrame;
- (void)emitNewFrame:(IOSurfaceRef)frame;

@end
@implementation v002_Screen_CapturePlugIn

Expand Down Expand Up @@ -95,6 +96,7 @@ - (id)init
if (self)
{
displayQueue = dispatch_queue_create("info.v002.v002ScreenCaptureQueue", DISPATCH_QUEUE_SERIAL);
colorspaceForDisplayID = NULL;
}

return self;
Expand All @@ -104,6 +106,10 @@ - (void) dealloc
{
dispatch_release(displayQueue);
if (displayStream) CFRelease(displayStream);

if(colorspaceForDisplayID)
CGColorSpaceRelease(colorspaceForDisplayID);

[super dealloc];
}

Expand Down Expand Up @@ -162,6 +168,26 @@ - (BOOL)execute:(id <QCPlugInContext>)context atTime:(NSTimeInterval)time withAr
// create a new CGDisplayStream
CGDirectDisplayID display = (CGDirectDisplayID) self.inputDisplayID;

// get the Colorspace from the displayID
for(NSScreen* screen in [NSScreen screens])
{
NSDictionary* screenDictionary = [screen deviceDescription];
NSNumber* screenID = [screenDictionary objectForKey:@"NSScreenNumber"];
CGDirectDisplayID screenDisplayID = [screenID unsignedIntValue];

if(display == screenDisplayID)
{
if(colorspaceForDisplayID)
{
CGColorSpaceRelease(colorspaceForDisplayID);
colorspaceForDisplayID = NULL;
}
colorspaceForDisplayID = CGColorSpaceRetain([screen colorSpace].CGColorSpace);

break;
}
}

CGDisplayModeRef mode = CGDisplayCopyDisplayMode(display);

size_t pixelWidth = CGDisplayModeGetPixelWidth(mode);
Expand All @@ -187,22 +213,17 @@ - (BOOL)execute:(id <QCPlugInContext>)context atTime:(NSTimeInterval)time withAr
});

CGDisplayStreamStart(displayStream);

}

IOSurfaceRef frameSurface = [self copyNewFrame];
if (frameSurface)
{
CGColorSpaceRef cspace = CGColorSpaceCreateWithName(kCGColorSpaceGenericRGB);

v002IOSurfaceImageProvider *output = [[v002IOSurfaceImageProvider alloc] initWithSurface:frameSurface isFlipped:YES colorSpace:cspace shouldColorMatch:YES];
v002IOSurfaceImageProvider *output = [[v002IOSurfaceImageProvider alloc] initWithSurface:frameSurface isFlipped:YES colorSpace:colorspaceForDisplayID shouldColorMatch:YES];

// v002IOSurfaceImageProvider has retained the surface and marked it as in use, so we can unmark it and release it now
CFRelease(frameSurface);
IOSurfaceDecrementUseCount(frameSurface);

CGColorSpaceRelease(cspace);

self.outputImage = output;

[output release];
Expand Down

1 comment on commit e08de74

@vade
Copy link
Member Author

@vade vade commented on e08de74 Dec 12, 2014

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Im an ass and should have put #5 not #1 and tried to fix it, and then reverted my revert. Sorry for the noise.

Please sign in to comment.