#pragma once
#if ENABLE(WEBGL)
#include "WebGLSharedObject.h"
#include <wtf/Vector.h>
namespace WebCore {
class WebGLTexture final : public WebGLSharedObject {
public:
enum TextureExtensionFlag {
TextureExtensionsDisabled = 0,
TextureExtensionFloatLinearEnabled = 1 << 0,
TextureExtensionHalfFloatLinearEnabled = 2 << 0
};
virtual ~WebGLTexture();
static Ref<WebGLTexture> create(WebGLRenderingContextBase&);
void setTarget(GCGLenum target, GCGLint maxLevel);
#if !USE(ANGLE)
void setParameteri(GCGLenum pname, GCGLint param);
void setParameterf(GCGLenum pname, GCGLfloat param);
#endif
GCGLenum getTarget() const { return m_target; }
#if !USE(ANGLE)
int getMinFilter() const { return m_minFilter; }
void setLevelInfo(GCGLenum target, GCGLint level, GCGLenum internalFormat, GCGLsizei width, GCGLsizei height, GCGLenum type);
bool canGenerateMipmaps();
void generateMipmapLevelInfo();
GCGLenum getInternalFormat(GCGLenum target, GCGLint level) const;
GCGLenum getType(GCGLenum target, GCGLint level) const;
GCGLsizei getWidth(GCGLenum target, GCGLint level) const;
GCGLsizei getHeight(GCGLenum target, GCGLint level) const;
bool isValid(GCGLenum target, GCGLint level) const;
void markInvalid(GCGLenum target, GCGLint level);
static bool isNPOT(GCGLsizei, GCGLsizei);
bool isNPOT() const;
bool needToUseBlackTexture(TextureExtensionFlag) const;
bool immutable() const { return m_immutable; }
void setImmutable() { m_immutable = true; }
bool isCompressed() const;
void setCompressed();
#endif
bool hasEverBeenBound() const { return object() && m_target; }
static GCGLint computeLevelCount(GCGLsizei width, GCGLsizei height);
private:
WebGLTexture(WebGLRenderingContextBase&);
void deleteObjectImpl(const WTF::AbstractLocker&, GraphicsContextGL*, PlatformGLObject) override;
bool isTexture() const override { return true; }
#if !USE(ANGLE)
class LevelInfo {
public:
LevelInfo()
: valid(false)
, internalFormat(0)
, width(0)
, height(0)
, type(0)
{
}
void setInfo(GCGLenum internalFmt, GCGLsizei w, GCGLsizei h, GCGLenum tp)
{
valid = true;
internalFormat = internalFmt;
width = w;
height = h;
type = tp;
}
bool valid;
GCGLenum internalFormat;
GCGLsizei width;
GCGLsizei height;
GCGLenum type;
};
void update();
#endif // !USE(ANGLE)
int mapTargetToIndex(GCGLenum) const;
#if !USE(ANGLE)
const LevelInfo* getLevelInfo(GCGLenum target, GCGLint level) const;
#endif // !USE(ANGLE)
GCGLenum m_target;
#if !USE(ANGLE)
GCGLenum m_minFilter;
GCGLenum m_magFilter;
GCGLenum m_wrapS;
GCGLenum m_wrapT;
Vector<Vector<LevelInfo>> m_info;
bool m_isNPOT;
bool m_isComplete;
bool m_needToUseBlackTexture;
bool m_isCompressed;
bool m_isFloatType;
bool m_isHalfFloatType;
bool m_isForWebGL1;
bool m_immutable { false };
#endif
};
}
#endif