-
Notifications
You must be signed in to change notification settings - Fork 228
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Exported video appears to be darker (colour shifting) #84
Comments
Upon further digging, this appears to be HDR related issue. The original is an HDR video, and it looks like the exported video did not preserve the HDR format. When using custom compositor though (which is the case for Cabbage), it must be updated to be HDR aware. I have tried rewriting the code above to use AVFoundation APIs directly, the video is exported correctly when HEVC preset is used. |
I add a demo to show how to support HDR video, you can pull the latest code. 41c7870#diff-2dc4dc28f7aa306658725e96363ac9a93d6e8642d3435f0b5a15407b463ed796R128 HDR could be supported by subclass |
预览正常,导出存在偏色,我这边测试的视频是偏红😭 |
@m-at-drigmo we have fixed this issue in our local code. Steps that you should do.
extension AVAsset {
@inlinable
public var containsHDRVideo: Bool {
tracks.contains { $0.hasMediaCharacteristic(.containsHDRVideo) }
}
}
extension AVAssetTrackResource {
public var containsHDRVideo: Bool {
asset?.containsHDRVideo ?? false
}
}
extension Timeline {
public var containsHDRVideo: Bool {
return videoChannel.contains { channel in
guard let item = channel as? TrackItem else {
return false
}
guard let assetTrackResource = item.resource as? AVAssetTrackResource else {
return false
}
return assetTrackResource.containsHDRVideo
}
}
}
|
I noticed that while exporting video using AVAssetExportSession, the result appears to be darker.
Attached below are the original and exported screenshot of the videos.
Is this expected? Any suggestions/workarounds to preserve as much of the visual quality of the original videos in the exported?
Original:
Exported:
The code:
The text was updated successfully, but these errors were encountered: