/// <summary>Converts a frame to a byte[] in the specified FourCC</summary> /// <param name="frameData">The frame data.</param> /// <param name="reuseOutputBuffer">if set to <c>true</c> [reuse output buffer].</param> /// <returns>The frame data in packed format</returns> public unsafe byte[] ConvertFromNV12(mfxFrameData frameData, bool reuseOutputBuffer = false) { if (!reuseOutputBuffer) outbuf = new byte[outbuf.Length]; }
public void UnlockFrame(ref mfxFrameSurface1 frame, ref mfxFrameData frameData) { throw new NotImplementedException(); }
unsafe static public Bitmap GetBitmap(this ILowLevelDecoder decoder, mfxFrameSurface1 surface) { #if false // if ( this.Data.MemId == IntPtr.Zero) { Trace.Assert(this.Info.FourCC == FourCC.NV12, "AsBitmap only works on NV12 currently"); Bitmap bmp = new Bitmap(this.Info.CropW, this.Info.CropH, PixelFormat.Format32bppArgb); Rectangle rect = new Rectangle(0, 0, bmp.Width, bmp.Height); // var a = new FrameFormatConverterFromNV12(FourCC.BGR4,bmp.Width, bmp.Height); var a = new NV12ToXXXXLowLevelConverter(); BitmapData bmpData = bmp.LockBits(rect, ImageLockMode.ReadWrite, bmp.PixelFormat); // Get the address of the first line. IntPtr ptr = bmpData.Scan0; a.ConvertFromNV12FrameSurface(FourCC.BGR4, this.Data.Y_ptr, this.Data.UV_ptr, (byte*)bmpData.Scan0, bmp.Width, bmp.Height, bmpData.Stride * bmpData.Height, this.Info.CropW, bmpData.Stride); return bmp; #else Trace.Assert(surface.Info.FourCC == FourCC.RGB4, "For vidmem, AsBitmap only works on RGB4 currently"); Bitmap bmp = new Bitmap(surface.Info.CropW, surface.Info.CropH, PixelFormat.Format32bppArgb); Rectangle rect = new Rectangle(0, 0, bmp.Width, bmp.Height); BitmapData bmpData; bmpData = bmp.LockBits(rect, ImageLockMode.ReadWrite, bmp.PixelFormat); // Get the address of the first line. IntPtr ptr = bmpData.Scan0; mfxFrameData fd = new mfxFrameData(); decoder.LockFrame((IntPtr)(&surface)); Console.WriteLine(fd.B); int pitch = fd.PitchHigh << 16 | fd.PitchLow; var zm = new byte[pitch * surface.Info.CropH]; //for (int i = 0; i < zm.Length; i++) //{ // zm[i] = 1; //} // Marshal.Copy(fd.B, zm, 0, zm.Length); // Console.WriteLine(zm.Sum(z => (long)z)); if (pitch == bmpData.Stride) { FastMemcpyMemmove.memcpy(ptr, fd.B, pitch * surface.Info.CropH); } else { int minpitch = Math.Min(pitch, bmpData.Stride); for (int i = 0; i < surface.Info.CropH; i++) { FastMemcpyMemmove.memcpy(ptr + bmpData.Stride * i, fd.B + pitch * i, minpitch); } } decoder.UnlockFrame((IntPtr)(&surface)); bmp.UnlockBits(bmpData); return bmp; } #endif }