mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-12 17:19:10 +01:00
35373c5185
This drops the "feature" to load level 0 from the custom texture and all other levels from the native one if the size matches. But in my opinion, when a custom texture only provide one level, no more should be used at all.
100 lines
2.5 KiB
C++
100 lines
2.5 KiB
C++
#pragma once
|
|
|
|
#include <string>
|
|
#include "VideoCommon/RenderBase.h"
|
|
|
|
namespace OGL
|
|
{
|
|
|
|
void ClearEFBCache();
|
|
|
|
enum GLSL_VERSION
|
|
{
|
|
GLSL_130,
|
|
GLSL_140,
|
|
GLSL_150, // and above
|
|
GLSLES_300, // GLES 3.0
|
|
GLSLES_310, // GLES 3.1
|
|
};
|
|
|
|
// ogl-only config, so not in VideoConfig.h
|
|
struct VideoConfig
|
|
{
|
|
bool bSupportsGLSLCache;
|
|
bool bSupportsGLPinnedMemory;
|
|
bool bSupportsGLSync;
|
|
bool bSupportsGLBaseVertex;
|
|
bool bSupportsGLBufferStorage;
|
|
bool bSupportsMSAA;
|
|
bool bSupportSampleShading;
|
|
GLSL_VERSION eSupportedGLSLVersion;
|
|
bool bSupportOGL31;
|
|
bool bSupportViewportFloat;
|
|
bool bSupportsAEP;
|
|
bool bSupportsDebug;
|
|
|
|
const char* gl_vendor;
|
|
const char* gl_renderer;
|
|
const char* gl_version;
|
|
const char* glsl_version;
|
|
|
|
s32 max_samples;
|
|
};
|
|
extern VideoConfig g_ogl_config;
|
|
|
|
class Renderer : public ::Renderer
|
|
{
|
|
public:
|
|
Renderer();
|
|
~Renderer();
|
|
|
|
static void Init();
|
|
static void Shutdown();
|
|
|
|
void SetColorMask() override;
|
|
void SetBlendMode(bool forceUpdate) override;
|
|
void SetScissorRect(const EFBRectangle& rc) override;
|
|
void SetGenerationMode() override;
|
|
void SetDepthMode() override;
|
|
void SetLogicOpMode() override;
|
|
void SetDitherMode() override;
|
|
void SetSamplerState(int stage, int texindex, bool custom_tex) override;
|
|
void SetInterlacingMode() override;
|
|
void SetViewport() override;
|
|
|
|
// TODO: Implement and use these
|
|
void ApplyState(bool bUseDstAlpha) override {}
|
|
void RestoreState() override {}
|
|
|
|
void RenderText(const std::string& text, int left, int top, u32 color) override;
|
|
void ShowEfbCopyRegions();
|
|
void FlipImageData(u8 *data, int w, int h, int pixel_width = 3);
|
|
|
|
u32 AccessEFB(EFBAccessType type, u32 x, u32 y, u32 poke_data) override;
|
|
|
|
u16 BBoxRead(int index) override;
|
|
void BBoxWrite(int index, u16 value) override;
|
|
|
|
void ResetAPIState() override;
|
|
void RestoreAPIState() override;
|
|
|
|
TargetRectangle ConvertEFBRectangle(const EFBRectangle& rc) override;
|
|
|
|
void SwapImpl(u32 xfbAddr, u32 fbWidth, u32 fbStride, u32 fbHeight, const EFBRectangle& rc, float Gamma) override;
|
|
|
|
void ClearScreen(const EFBRectangle& rc, bool colorEnable, bool alphaEnable, bool zEnable, u32 color, u32 z) override;
|
|
|
|
void ReinterpretPixelData(unsigned int convtype) override;
|
|
|
|
bool SaveScreenshot(const std::string &filename, const TargetRectangle &rc) override;
|
|
|
|
int GetMaxTextureSize() override;
|
|
|
|
private:
|
|
void UpdateEFBCache(EFBAccessType type, u32 cacheRectIdx, const EFBRectangle& efbPixelRc, const TargetRectangle& targetPixelRc, const u32* data);
|
|
|
|
void BlitScreen(TargetRectangle src, TargetRectangle dst, GLuint src_texture, int src_width, int src_height);
|
|
};
|
|
|
|
}
|