зеркало из https://github.com/mozilla/gecko-dev.git
152 строки
5.8 KiB
C++
152 строки
5.8 KiB
C++
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
#ifndef MacIOSurface_h__
|
|
#define MacIOSurface_h__
|
|
#ifdef XP_DARWIN
|
|
# include <CoreVideo/CoreVideo.h>
|
|
# include <IOSurface/IOSurface.h>
|
|
# include <QuartzCore/QuartzCore.h>
|
|
# include <dlfcn.h>
|
|
|
|
# include "mozilla/gfx/Types.h"
|
|
# include "CFTypeRefPtr.h"
|
|
|
|
namespace mozilla {
|
|
namespace gl {
|
|
class GLContext;
|
|
}
|
|
} // namespace mozilla
|
|
|
|
struct _CGLContextObject;
|
|
|
|
typedef _CGLContextObject* CGLContextObj;
|
|
typedef uint32_t IOSurfaceID;
|
|
|
|
# ifdef XP_IOS
|
|
typedef kern_return_t IOReturn;
|
|
typedef int CGLError;
|
|
# endif
|
|
|
|
# ifdef XP_MACOSX
|
|
# import <OpenGL/OpenGL.h>
|
|
# else
|
|
# import <OpenGLES/ES2/gl.h>
|
|
# endif
|
|
|
|
# include "2D.h"
|
|
# include "mozilla/RefCounted.h"
|
|
# include "mozilla/RefPtr.h"
|
|
|
|
class MacIOSurface final
|
|
: public mozilla::external::AtomicRefCounted<MacIOSurface> {
|
|
public:
|
|
MOZ_DECLARE_REFCOUNTED_VIRTUAL_TYPENAME(MacIOSurface)
|
|
typedef mozilla::gfx::SourceSurface SourceSurface;
|
|
typedef mozilla::gfx::DrawTarget DrawTarget;
|
|
typedef mozilla::gfx::BackendType BackendType;
|
|
typedef mozilla::gfx::IntSize IntSize;
|
|
typedef mozilla::gfx::YUVColorSpace YUVColorSpace;
|
|
typedef mozilla::gfx::ColorRange ColorRange;
|
|
|
|
// The usage count of the IOSurface is increased by 1 during the lifetime
|
|
// of the MacIOSurface instance.
|
|
// MacIOSurface holds a reference to the corresponding IOSurface.
|
|
|
|
static already_AddRefed<MacIOSurface> CreateIOSurface(int aWidth, int aHeight,
|
|
bool aHasAlpha = true);
|
|
static already_AddRefed<MacIOSurface> CreateNV12Surface(
|
|
const IntSize& aYSize, const IntSize& aCbCrSize,
|
|
YUVColorSpace aColorSpace, ColorRange aColorRange);
|
|
static already_AddRefed<MacIOSurface> CreateYUV422Surface(
|
|
const IntSize& aSize, YUVColorSpace aColorSpace, ColorRange aColorRange);
|
|
static void ReleaseIOSurface(MacIOSurface* aIOSurface);
|
|
static already_AddRefed<MacIOSurface> LookupSurface(
|
|
IOSurfaceID aSurfaceID, bool aHasAlpha = true,
|
|
mozilla::gfx::YUVColorSpace aColorSpace =
|
|
mozilla::gfx::YUVColorSpace::Identity);
|
|
|
|
explicit MacIOSurface(CFTypeRefPtr<IOSurfaceRef> aIOSurfaceRef,
|
|
bool aHasAlpha = true,
|
|
mozilla::gfx::YUVColorSpace aColorSpace =
|
|
mozilla::gfx::YUVColorSpace::Identity);
|
|
|
|
~MacIOSurface();
|
|
IOSurfaceID GetIOSurfaceID() const;
|
|
void* GetBaseAddress() const;
|
|
void* GetBaseAddressOfPlane(size_t planeIndex) const;
|
|
size_t GetPlaneCount() const;
|
|
OSType GetPixelFormat() const;
|
|
// GetWidth() and GetHeight() return values in "display pixels". A
|
|
// "display pixel" is the smallest fully addressable part of a display.
|
|
// But in HiDPI modes each "display pixel" corresponds to more than one
|
|
// device pixel. Use GetDevicePixel**() to get device pixels.
|
|
size_t GetWidth(size_t plane = 0) const;
|
|
size_t GetHeight(size_t plane = 0) const;
|
|
IntSize GetSize(size_t plane = 0) const {
|
|
return IntSize(GetWidth(plane), GetHeight(plane));
|
|
}
|
|
size_t GetDevicePixelWidth(size_t plane = 0) const;
|
|
size_t GetDevicePixelHeight(size_t plane = 0) const;
|
|
size_t GetBytesPerRow(size_t plane = 0) const;
|
|
size_t GetAllocSize() const;
|
|
void Lock(bool aReadOnly = true);
|
|
void Unlock(bool aReadOnly = true);
|
|
bool IsLocked() const { return mIsLocked; }
|
|
void IncrementUseCount();
|
|
void DecrementUseCount();
|
|
bool HasAlpha() const { return mHasAlpha; }
|
|
mozilla::gfx::SurfaceFormat GetFormat() const;
|
|
mozilla::gfx::SurfaceFormat GetReadFormat() const;
|
|
// This would be better suited on MacIOSurfaceImage type, however due to the
|
|
// current data structure, this is not possible as only the IOSurfaceRef is
|
|
// being used across.
|
|
void SetYUVColorSpace(YUVColorSpace aColorSpace) {
|
|
mColorSpace = aColorSpace;
|
|
}
|
|
YUVColorSpace GetYUVColorSpace() const { return mColorSpace; }
|
|
bool IsFullRange() const {
|
|
return GetPixelFormat() == kCVPixelFormatType_420YpCbCr8BiPlanarFullRange;
|
|
}
|
|
mozilla::gfx::ColorRange GetColorRange() const {
|
|
if (IsFullRange()) return mozilla::gfx::ColorRange::FULL;
|
|
return mozilla::gfx::ColorRange::LIMITED;
|
|
}
|
|
|
|
// We would like to forward declare NSOpenGLContext, but it is an @interface
|
|
// and this file is also used from c++, so we use a void *.
|
|
CGLError CGLTexImageIOSurface2D(
|
|
mozilla::gl::GLContext* aGL, CGLContextObj ctxt, size_t plane,
|
|
mozilla::gfx::SurfaceFormat* aOutReadFormat = nullptr);
|
|
CGLError CGLTexImageIOSurface2D(CGLContextObj ctxt, GLenum target,
|
|
GLenum internalFormat, GLsizei width,
|
|
GLsizei height, GLenum format, GLenum type,
|
|
GLuint plane) const;
|
|
already_AddRefed<SourceSurface> GetAsSurface();
|
|
|
|
// Creates a DrawTarget that wraps the data in the IOSurface. Rendering to
|
|
// this DrawTarget directly manipulates the contents of the IOSurface.
|
|
// Only call when the surface is already locked for writing!
|
|
// The returned DrawTarget must only be used while the surface is still
|
|
// locked.
|
|
// Also, only call this if you're reasonably sure that the DrawTarget of the
|
|
// selected backend supports the IOSurface's SurfaceFormat.
|
|
already_AddRefed<DrawTarget> GetAsDrawTargetLocked(BackendType aBackendType);
|
|
|
|
static size_t GetMaxWidth();
|
|
static size_t GetMaxHeight();
|
|
CFTypeRefPtr<IOSurfaceRef> GetIOSurfaceRef() { return mIOSurfaceRef; }
|
|
|
|
private:
|
|
CFTypeRefPtr<IOSurfaceRef> mIOSurfaceRef;
|
|
const bool mHasAlpha;
|
|
YUVColorSpace mColorSpace = YUVColorSpace::Identity;
|
|
bool mIsLocked = false;
|
|
};
|
|
|
|
#endif
|
|
#endif
|