Blame view

3rdparty/opencv-4.5.4/samples/winrt/ImageManipulations/MediaExtensions/Common/BufferLock.h 2.84 KB
f4334277   Hu Chunming   提交3rdparty
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
  // THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
  // ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
  // THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
  // PARTICULAR PURPOSE.
  //
  // Copyright (c) Microsoft Corporation. All rights reserved
  
  
  #pragma once
  
  
  //////////////////////////////////////////////////////////////////////////
  //  VideoBufferLock
  //
  //  Description:
  //  Locks a video buffer that might or might not support IMF2DBuffer.
  //
  //////////////////////////////////////////////////////////////////////////
  
  class VideoBufferLock
  {
  public:
      VideoBufferLock(IMFMediaBuffer *pBuffer) : m_p2DBuffer(NULL)
      {
          m_pBuffer = pBuffer;
          m_pBuffer->AddRef();
  
          // Query for the 2-D buffer interface. OK if this fails.
          m_pBuffer->QueryInterface(IID_PPV_ARGS(&m_p2DBuffer));
      }
  
      ~VideoBufferLock()
      {
          UnlockBuffer();
          SafeRelease(&m_pBuffer);
          SafeRelease(&m_p2DBuffer);
      }
  
      // LockBuffer:
      // Locks the buffer. Returns a pointer to scan line 0 and returns the stride.
  
      // The caller must provide the default stride as an input parameter, in case
      // the buffer does not expose IMF2DBuffer. You can calculate the default stride
      // from the media type.
  
      HRESULT LockBuffer(
          LONG  lDefaultStride,    // Minimum stride (with no padding).
          DWORD dwHeightInPixels,  // Height of the image, in pixels.
          BYTE  **ppbScanLine0,    // Receives a pointer to the start of scan line 0.
          LONG  *plStride          // Receives the actual stride.
          )
      {
          HRESULT hr = S_OK;
  
          // Use the 2-D version if available.
          if (m_p2DBuffer)
          {
              hr = m_p2DBuffer->Lock2D(ppbScanLine0, plStride);
          }
          else
          {
              // Use non-2D version.
              BYTE *pData = NULL;
  
              hr = m_pBuffer->Lock(&pData, NULL, NULL);
              if (SUCCEEDED(hr))
              {
                  *plStride = lDefaultStride;
                  if (lDefaultStride < 0)
                  {
                      // Bottom-up orientation. Return a pointer to the start of the
                      // last row *in memory* which is the top row of the image.
                      *ppbScanLine0 = pData + abs(lDefaultStride) * (dwHeightInPixels - 1);
                  }
                  else
                  {
                      // Top-down orientation. Return a pointer to the start of the
                      // buffer.
                      *ppbScanLine0 = pData;
                  }
              }
          }
          return hr;
      }
  
      HRESULT UnlockBuffer()
      {
          if (m_p2DBuffer)
          {
              return m_p2DBuffer->Unlock2D();
          }
          else
          {
              return m_pBuffer->Unlock();
          }
      }
  
  private:
      IMFMediaBuffer  *m_pBuffer;
      IMF2DBuffer     *m_p2DBuffer;
  };