HEVCRecorder.cs 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. /*
  2. * NatCorder
  3. * Copyright (c) 2020 Yusuf Olokoba.
  4. */
  5. namespace NatSuite.Recorders {
  6. using System;
  7. using System.Threading.Tasks;
  8. using Internal;
  9. /// <summary>
  10. /// HEVC video recorder.
  11. /// </summary>
  12. public sealed class HEVCRecorder : IMediaRecorder {
  13. #region --Client API--
  14. /// <summary>
  15. /// Video size.
  16. /// </summary>
  17. public (int width, int height) frameSize => recorder.frameSize;
  18. /// <summary>
  19. /// Create a HEVC recorder.
  20. /// </summary>
  21. /// <param name="width">Video width.</param>
  22. /// <param name="height">Video height.</param>
  23. /// <param name="frameRate">Video framerate.</param>
  24. /// <param name="sampleRate">Audio sample rate. Pass 0 for no audio.</param>
  25. /// <param name="channelCount">Audio channel count. Pass 0 for no audio.</param>
  26. /// <param name="bitrate">Video bitrate in bits per second.</param>
  27. /// <param name="keyframeInterval">Keyframe interval in seconds.</param>
  28. public HEVCRecorder (int width, int height, float frameRate, int sampleRate = 0, int channelCount = 0, int bitrate = (int)(960 * 540 * 11.4f), int keyframeInterval = 3) => this.recorder = new NativeRecorder((callback, context) => Bridge.CreateHEVCRecorder(width, height, frameRate, bitrate, keyframeInterval, sampleRate, channelCount, Utility.GetPath(@".mp4"), callback, context));
  29. /// <summary>
  30. /// Commit a video pixel buffer for encoding.
  31. /// The pixel buffer MUST have an RGBA8888 pixel layout.
  32. /// </summary>
  33. /// <param name="pixelBuffer">Pixel buffer containing video frame to commit.</param>
  34. /// <param name="timestamp">Frame timestamp in nanoseconds.</param>
  35. public void CommitFrame<T> (T[] pixelBuffer, long timestamp) where T : struct => recorder.CommitFrame(pixelBuffer, timestamp);
  36. /// <summary>
  37. /// Commit a video pixel buffer for encoding.
  38. /// The pixel buffer MUST have an RGBA8888 pixel layout.
  39. /// </summary>
  40. /// <param name="nativeBuffer">Pixel buffer in native memory to commit.</param>
  41. /// <param name="timestamp">Frame timestamp in nanoseconds.</param>
  42. public void CommitFrame (IntPtr nativeBuffer, long timestamp) => recorder.CommitFrame(nativeBuffer, timestamp);
  43. /// <summary>
  44. /// Commit an audio sample buffer for encoding.
  45. /// </summary>
  46. /// <param name="sampleBuffer">Linear PCM audio sample buffer, interleaved by channel.</param>
  47. /// <param name="timestamp">Sample buffer timestamp in nanoseconds.</param>
  48. public void CommitSamples (float[] sampleBuffer, long timestamp) => recorder.CommitSamples(sampleBuffer, timestamp);
  49. /// <summary>
  50. /// Finish writing and return the path to the recorded media file.
  51. /// </summary>
  52. public Task<string> FinishWriting () => recorder.FinishWriting();
  53. #endregion
  54. private readonly IMediaRecorder recorder;
  55. }
  56. }