#ifndef TextureMapper_h
#define TextureMapper_h
#if USE(TEXTURE_MAPPER)
#if (PLATFORM(GTK) || PLATFORM(EFL)) && USE(OPENGL_ES_2)
#define TEXMAP_OPENGL_ES_2
#endif
#include "GraphicsContext.h"
#include "IntRect.h"
#include "IntSize.h"
#include "TransformationMatrix.h"
namespace WebCore {
class BitmapTexturePool;
class GraphicsLayer;
class TextureMapper;
class FilterOperations;
class BitmapTexture : public RefCounted<BitmapTexture> {
public:
enum Flag {
NoFlag = 0,
SupportsAlpha = 0x01
};
enum UpdateContentsFlag {
UpdateCanModifyOriginalImageData,
UpdateCannotModifyOriginalImageData
};
typedef unsigned Flags;
BitmapTexture()
: m_flags(0)
{
}
virtual ~BitmapTexture() { }
virtual bool isBackedByOpenGL() const { return false; }
virtual IntSize size() const = 0;
virtual void updateContents(Image*, const IntRect&, const IntPoint& offset, UpdateContentsFlag) = 0;
virtual void updateContents(TextureMapper*, GraphicsLayer*, const IntRect& target, const IntPoint& offset, UpdateContentsFlag);
virtual void updateContents(const void*, const IntRect& target, const IntPoint& offset, int bytesPerLine, UpdateContentsFlag) = 0;
virtual bool isValid() const = 0;
inline Flags flags() const { return m_flags; }
virtual int bpp() const { return 32; }
virtual bool canReuseWith(const IntSize& , Flags = 0) { return false; }
void reset(const IntSize& size, Flags flags = 0)
{
m_flags = flags;
m_contentSize = size;
didReset();
}
virtual void didReset() { }
inline IntSize contentSize() const { return m_contentSize; }
inline int numberOfBytes() const { return size().width() * size().height() * bpp() >> 3; }
inline bool isOpaque() const { return !(m_flags & SupportsAlpha); }
#if ENABLE(CSS_FILTERS)
virtual PassRefPtr<BitmapTexture> applyFilters(TextureMapper*, const FilterOperations&) { return this; }
#endif
protected:
IntSize m_contentSize;
private:
Flags m_flags;
};
class TextureMapper {
WTF_MAKE_FAST_ALLOCATED;
friend class BitmapTexture;
public:
enum AccelerationMode { SoftwareMode, OpenGLMode };
enum PaintFlag {
PaintingMirrored = 1 << 0,
};
enum WrapMode {
StretchWrap,
RepeatWrap
};
typedef unsigned PaintFlags;
static std::unique_ptr<TextureMapper> create(AccelerationMode newMode = SoftwareMode);
explicit TextureMapper(AccelerationMode);
virtual ~TextureMapper();
enum ExposedEdges {
NoEdges = 0,
LeftEdge = 1 << 0,
RightEdge = 1 << 1,
TopEdge = 1 << 2,
BottomEdge = 1 << 3,
AllEdges = LeftEdge | RightEdge | TopEdge | BottomEdge,
};
virtual void drawBorder(const Color&, float borderWidth, const FloatRect&, const TransformationMatrix&) = 0;
virtual void drawNumber(int number, const Color&, const FloatPoint&, const TransformationMatrix&) = 0;
virtual void drawTexture(const BitmapTexture&, const FloatRect& target, const TransformationMatrix& modelViewMatrix = TransformationMatrix(), float opacity = 1.0f, unsigned exposedEdges = AllEdges) = 0;
virtual void drawSolidColor(const FloatRect&, const TransformationMatrix&, const Color&) = 0;
virtual void bindSurface(BitmapTexture* surface) = 0;
void setGraphicsContext(GraphicsContext* context) { m_context = context; }
GraphicsContext* graphicsContext() { return m_context; }
virtual void beginClip(const TransformationMatrix&, const FloatRect&) = 0;
virtual void endClip() = 0;
virtual IntRect clipBounds() = 0;
virtual PassRefPtr<BitmapTexture> createTexture() = 0;
void setImageInterpolationQuality(InterpolationQuality quality) { m_interpolationQuality = quality; }
void setTextDrawingMode(TextDrawingModeFlags mode) { m_textDrawingMode = mode; }
InterpolationQuality imageInterpolationQuality() const { return m_interpolationQuality; }
TextDrawingModeFlags textDrawingMode() const { return m_textDrawingMode; }
AccelerationMode accelerationMode() const { return m_accelerationMode; }
virtual void beginPainting(PaintFlags = 0) { }
virtual void endPainting() { }
void setMaskMode(bool m) { m_isMaskMode = m; }
virtual IntSize maxTextureSize() const = 0;
virtual PassRefPtr<BitmapTexture> acquireTextureFromPool(const IntSize&, const BitmapTexture::Flags = BitmapTexture::SupportsAlpha);
void setPatternTransform(const TransformationMatrix& p) { m_patternTransform = p; }
void setWrapMode(WrapMode m) { m_wrapMode = m; }
protected:
GraphicsContext* m_context;
bool isInMaskMode() const { return m_isMaskMode; }
WrapMode wrapMode() const { return m_wrapMode; }
const TransformationMatrix& patternTransform() const { return m_patternTransform; }
private:
#if USE(TEXTURE_MAPPER_GL)
static std::unique_ptr<TextureMapper> platformCreateAccelerated();
#else
static std::unique_ptr<TextureMapper> platformCreateAccelerated()
{
return nullptr;
}
#endif
InterpolationQuality m_interpolationQuality;
TextDrawingModeFlags m_textDrawingMode;
std::unique_ptr<BitmapTexturePool> m_texturePool;
AccelerationMode m_accelerationMode;
bool m_isMaskMode;
TransformationMatrix m_patternTransform;
WrapMode m_wrapMode;
};
}
#endif
#endif