Cocoa Port: NEW FEATURE - Users can now apply custom colors to individual HUD line items.

This commit is contained in:
rogerman 2017-09-05 13:12:31 -07:00
parent 2b9bc2509a
commit 4cfa910e75
18 changed files with 1719 additions and 160 deletions

View File

@ -301,7 +301,7 @@ enum OGLVertexAttributeID
{ {
OGLVertexAttributeID_Position = 0, OGLVertexAttributeID_Position = 0,
OGLVertexAttributeID_TexCoord0 = 8, OGLVertexAttributeID_TexCoord0 = 8,
OGLVertexAttributeID_Color = 3, OGLVertexAttributeID_Color = 3
}; };
enum OGLTextureUnitID enum OGLTextureUnitID

View File

@ -93,6 +93,13 @@ void ClientDisplayView::__InstanceInit(const ClientDisplayViewProperties &props)
_showCPULoadAverage = false; _showCPULoadAverage = false;
_showRTC = false; _showRTC = false;
_hudColorVideoFPS = 0xFFFFFFFF;
_hudColorRender3DFPS = 0xFFFFFFFF;
_hudColorFrameIndex = 0xFFFFFFFF;
_hudColorLagFrameCount = 0xFFFFFFFF;
_hudColorCPULoadAverage = 0xFFFFFFFF;
_hudColorRTC = 0xFFFFFFFF;
_clientFrameInfo.videoFPS = 0; _clientFrameInfo.videoFPS = 0;
_ndsFrameInfo.clear(); _ndsFrameInfo.clear();
@ -560,6 +567,102 @@ void ClientDisplayView::SetHUDShowRTC(const bool visibleState)
this->UpdateView(); this->UpdateView();
} }
uint32_t ClientDisplayView::GetHUDColorVideoFPS() const
{
return this->_hudColorVideoFPS;
}
void ClientDisplayView::SetHUDColorVideoFPS(uint32_t color32)
{
this->_hudColorVideoFPS = color32;
pthread_mutex_lock(&this->_mutexHUDString);
this->_hudNeedsUpdate = true;
pthread_mutex_unlock(&this->_mutexHUDString);
this->UpdateView();
}
uint32_t ClientDisplayView::GetHUDColorRender3DFPS() const
{
return this->_hudColorRender3DFPS;
}
void ClientDisplayView::SetHUDColorRender3DFPS(uint32_t color32)
{
this->_hudColorRender3DFPS = color32;
pthread_mutex_lock(&this->_mutexHUDString);
this->_hudNeedsUpdate = true;
pthread_mutex_unlock(&this->_mutexHUDString);
this->UpdateView();
}
uint32_t ClientDisplayView::GetHUDColorFrameIndex() const
{
return this->_hudColorFrameIndex;
}
void ClientDisplayView::SetHUDColorFrameIndex(uint32_t color32)
{
this->_hudColorFrameIndex = color32;
pthread_mutex_lock(&this->_mutexHUDString);
this->_hudNeedsUpdate = true;
pthread_mutex_unlock(&this->_mutexHUDString);
this->UpdateView();
}
uint32_t ClientDisplayView::GetHUDColorLagFrameCount() const
{
return this->_hudColorLagFrameCount;
}
void ClientDisplayView::SetHUDColorLagFrameCount(uint32_t color32)
{
this->_hudColorLagFrameCount = color32;
pthread_mutex_lock(&this->_mutexHUDString);
this->_hudNeedsUpdate = true;
pthread_mutex_unlock(&this->_mutexHUDString);
this->UpdateView();
}
uint32_t ClientDisplayView::GetHUDColorCPULoadAverage() const
{
return this->_hudColorCPULoadAverage;
}
void ClientDisplayView::SetHUDColorCPULoadAverage(uint32_t color32)
{
this->_hudColorCPULoadAverage = color32;
pthread_mutex_lock(&this->_mutexHUDString);
this->_hudNeedsUpdate = true;
pthread_mutex_unlock(&this->_mutexHUDString);
this->UpdateView();
}
uint32_t ClientDisplayView::GetHUDColorRTC() const
{
return this->_hudColorRTC;
}
void ClientDisplayView::SetHUDColorRTC(uint32_t color32)
{
this->_hudColorRTC = color32;
pthread_mutex_lock(&this->_mutexHUDString);
this->_hudNeedsUpdate = true;
pthread_mutex_unlock(&this->_mutexHUDString);
this->UpdateView();
}
bool ClientDisplayView::HUDNeedsUpdate() bool ClientDisplayView::HUDNeedsUpdate()
{ {
pthread_mutex_lock(&this->_mutexHUDString); pthread_mutex_lock(&this->_mutexHUDString);
@ -1186,7 +1289,7 @@ void ClientDisplay3DView::SetSourceDeposterize(bool useDeposterize)
this->_useDeposterize = (this->_canFilterOnGPU) ? useDeposterize : false; this->_useDeposterize = (this->_canFilterOnGPU) ? useDeposterize : false;
} }
void ClientDisplay3DView::SetHUDVertices(float viewportWidth, float viewportHeight, float *vtxBufferPtr) void ClientDisplay3DView::SetHUDPositionVertices(float viewportWidth, float viewportHeight, float *vtxPositionBufferPtr)
{ {
pthread_mutex_lock(&this->_mutexHUDString); pthread_mutex_lock(&this->_mutexHUDString);
std::string hudString = this->_hudString; std::string hudString = this->_hudString;
@ -1203,10 +1306,10 @@ void ClientDisplay3DView::SetHUDVertices(float viewportWidth, float viewportHeig
// First, calculate the vertices of the text box. // First, calculate the vertices of the text box.
// The text box should always be the first character in the string. // The text box should always be the first character in the string.
vtxBufferPtr[0] = 0.0f; vtxBufferPtr[1] = 0.0f; vtxPositionBufferPtr[0] = 0.0f; vtxPositionBufferPtr[1] = 0.0f;
vtxBufferPtr[2] = charLocX; vtxBufferPtr[3] = 0.0f; vtxPositionBufferPtr[2] = charLocX; vtxPositionBufferPtr[3] = 0.0f;
vtxBufferPtr[4] = charLocX; vtxBufferPtr[5] = -textBoxTextOffset; vtxPositionBufferPtr[4] = charLocX; vtxPositionBufferPtr[5] = -textBoxTextOffset;
vtxBufferPtr[6] = 0.0f; vtxBufferPtr[7] = -textBoxTextOffset; vtxPositionBufferPtr[6] = 0.0f; vtxPositionBufferPtr[7] = -textBoxTextOffset;
// Calculate the vertices of the remaining characters in the string. // Calculate the vertices of the remaining characters in the string.
for (size_t i = 1, j = 8; i < length; i++, j+=8) for (size_t i = 1, j = 8; i < length; i++, j+=8)
@ -1220,8 +1323,8 @@ void ClientDisplay3DView::SetHUDVertices(float viewportWidth, float viewportHeig
textBoxWidth = charLocX; textBoxWidth = charLocX;
} }
vtxBufferPtr[5] -= lineHeight; vtxPositionBufferPtr[5] -= lineHeight;
vtxBufferPtr[7] -= lineHeight; vtxPositionBufferPtr[7] -= lineHeight;
charLocX = textBoxTextOffset; charLocX = textBoxTextOffset;
charLocY -= lineHeight; charLocY -= lineHeight;
@ -1230,10 +1333,10 @@ void ClientDisplay3DView::SetHUDVertices(float viewportWidth, float viewportHeig
const float charWidth = this->_glyphInfo[c].width * charSize / (float)this->_glyphTileSize; const float charWidth = this->_glyphInfo[c].width * charSize / (float)this->_glyphTileSize;
vtxBufferPtr[j+0] = charLocX; vtxBufferPtr[j+1] = charLocY + charSize; // Top Left vtxPositionBufferPtr[j+0] = charLocX; vtxPositionBufferPtr[j+1] = charLocY + charSize; // Top Left
vtxBufferPtr[j+2] = charLocX + charWidth; vtxBufferPtr[j+3] = charLocY + charSize; // Top Right vtxPositionBufferPtr[j+2] = charLocX + charWidth; vtxPositionBufferPtr[j+3] = charLocY + charSize; // Top Right
vtxBufferPtr[j+4] = charLocX + charWidth; vtxBufferPtr[j+5] = charLocY; // Bottom Right vtxPositionBufferPtr[j+4] = charLocX + charWidth; vtxPositionBufferPtr[j+5] = charLocY; // Bottom Right
vtxBufferPtr[j+6] = charLocX; vtxBufferPtr[j+7] = charLocY; // Bottom Left vtxPositionBufferPtr[j+6] = charLocX; vtxPositionBufferPtr[j+7] = charLocY; // Bottom Left
charLocX += (charWidth + (charSize * 0.03f) + 0.10f); charLocX += (charWidth + (charSize * 0.03f) + 0.10f);
} }
@ -1258,19 +1361,122 @@ void ClientDisplay3DView::SetHUDVertices(float viewportWidth, float viewportHeig
boxOffset *= this->_scaleFactor; boxOffset *= this->_scaleFactor;
// Set the width of the text box // Set the width of the text box
vtxBufferPtr[2] += textBoxWidth; vtxPositionBufferPtr[2] += textBoxWidth;
vtxBufferPtr[4] += textBoxWidth; vtxPositionBufferPtr[4] += textBoxWidth;
// Scale and translate the box // Scale and translate the box
for (size_t i = 0; i < (length * 8); i+=2) for (size_t i = 0; i < (length * 8); i+=2)
{ {
// Scale // Scale
vtxBufferPtr[i+0] *= textBoxScale; vtxPositionBufferPtr[i+0] *= textBoxScale;
vtxBufferPtr[i+1] *= textBoxScale; vtxPositionBufferPtr[i+1] *= textBoxScale;
// Translate // Translate
vtxBufferPtr[i+0] += boxOffset - (viewportWidth / 2.0f); vtxPositionBufferPtr[i+0] += boxOffset - (viewportWidth / 2.0f);
vtxBufferPtr[i+1] += (viewportHeight / 2.0f) - boxOffset; vtxPositionBufferPtr[i+1] += (viewportHeight / 2.0f) - boxOffset;
}
}
void ClientDisplay3DView::SetHUDColorVertices(uint32_t *vtxColorBufferPtr)
{
pthread_mutex_lock(&this->_mutexHUDString);
std::string hudString = this->_hudString;
pthread_mutex_unlock(&this->_mutexHUDString);
const char *cString = hudString.c_str();
const size_t length = hudString.length();
uint32_t currentColor = 0x40000000;
// First, calculate the color of the text box.
// The text box should always be the first character in the string.
vtxColorBufferPtr[0] = currentColor;
vtxColorBufferPtr[1] = currentColor;
vtxColorBufferPtr[2] = currentColor;
vtxColorBufferPtr[3] = currentColor;
// Calculate the colors of the remaining characters in the string.
bool alreadyColoredVideoFPS = false;
bool alreadyColoredRender3DFPS = false;
bool alreadyColoredFrameIndex = false;
bool alreadyColoredLagFrameCount = false;
bool alreadyColoredCPULoadAverage = false;
bool alreadyColoredRTC = false;
if (this->_showVideoFPS)
{
currentColor = this->_hudColorVideoFPS;
alreadyColoredVideoFPS = true;
}
else if (this->_showRender3DFPS)
{
currentColor = this->_hudColorRender3DFPS;
alreadyColoredRender3DFPS = true;
}
else if (this->_showFrameIndex)
{
currentColor = this->_hudColorFrameIndex;
alreadyColoredFrameIndex = true;
}
else if (this->_showLagFrameCount)
{
currentColor = this->_hudColorLagFrameCount;
alreadyColoredLagFrameCount = true;
}
else if (this->_showCPULoadAverage)
{
currentColor = this->_hudColorCPULoadAverage;
alreadyColoredCPULoadAverage = true;
}
else if (this->_showRTC)
{
currentColor = this->_hudColorRTC;
alreadyColoredRTC = true;
}
for (size_t i = 1, j = 4; i < length; i++, j+=4)
{
const char c = cString[i];
if (c == '\n')
{
if (this->_showVideoFPS && !alreadyColoredVideoFPS)
{
currentColor = this->_hudColorVideoFPS;
alreadyColoredVideoFPS = true;
}
else if (this->_showRender3DFPS && !alreadyColoredRender3DFPS)
{
currentColor = this->_hudColorRender3DFPS;
alreadyColoredRender3DFPS = true;
}
else if (this->_showFrameIndex && !alreadyColoredFrameIndex)
{
currentColor = this->_hudColorFrameIndex;
alreadyColoredFrameIndex = true;
}
else if (this->_showLagFrameCount && !alreadyColoredLagFrameCount)
{
currentColor = this->_hudColorLagFrameCount;
alreadyColoredLagFrameCount = true;
}
else if (this->_showCPULoadAverage && !alreadyColoredCPULoadAverage)
{
currentColor = this->_hudColorCPULoadAverage;
alreadyColoredCPULoadAverage = true;
}
else if (this->_showRTC && !alreadyColoredRTC)
{
currentColor = this->_hudColorRTC;
alreadyColoredRTC = true;
}
continue;
}
vtxColorBufferPtr[j+0] = currentColor; // Top Left
vtxColorBufferPtr[j+1] = currentColor; // Top Right
vtxColorBufferPtr[j+2] = currentColor; // Bottom Right
vtxColorBufferPtr[j+3] = currentColor; // Bottom Left
} }
} }

View File

@ -31,6 +31,7 @@
#define HUD_MAX_CHARACTERS 2048 #define HUD_MAX_CHARACTERS 2048
#define HUD_VERTEX_ATTRIBUTE_BUFFER_SIZE (sizeof(float) * HUD_MAX_CHARACTERS * (2 * 4)) #define HUD_VERTEX_ATTRIBUTE_BUFFER_SIZE (sizeof(float) * HUD_MAX_CHARACTERS * (2 * 4))
#define HUD_VERTEX_COLOR_ATTRIBUTE_BUFFER_SIZE (sizeof(uint32_t) * HUD_MAX_CHARACTERS * 4)
#define HUD_TEXTBOX_BASEGLYPHSIZE 64.0 #define HUD_TEXTBOX_BASEGLYPHSIZE 64.0
#define HUD_TEXTBOX_BASE_SCALE (1.0/3.0) #define HUD_TEXTBOX_BASE_SCALE (1.0/3.0)
#define HUD_TEXTBOX_MIN_SCALE 0.70 #define HUD_TEXTBOX_MIN_SCALE 0.70
@ -160,6 +161,13 @@ protected:
bool _showCPULoadAverage; bool _showCPULoadAverage;
bool _showRTC; bool _showRTC;
uint32_t _hudColorVideoFPS;
uint32_t _hudColorRender3DFPS;
uint32_t _hudColorFrameIndex;
uint32_t _hudColorLagFrameCount;
uint32_t _hudColorCPULoadAverage;
uint32_t _hudColorRTC;
ClientFrameInfo _clientFrameInfo; ClientFrameInfo _clientFrameInfo;
NDSFrameInfo _ndsFrameInfo; NDSFrameInfo _ndsFrameInfo;
@ -259,6 +267,18 @@ public:
virtual void SetHUDShowCPULoadAverage(const bool visibleState); virtual void SetHUDShowCPULoadAverage(const bool visibleState);
bool GetHUDShowRTC() const; bool GetHUDShowRTC() const;
virtual void SetHUDShowRTC(const bool visibleState); virtual void SetHUDShowRTC(const bool visibleState);
uint32_t GetHUDColorVideoFPS() const;
virtual void SetHUDColorVideoFPS(uint32_t color32);
uint32_t GetHUDColorRender3DFPS() const;
virtual void SetHUDColorRender3DFPS(uint32_t color32);
uint32_t GetHUDColorFrameIndex() const;
virtual void SetHUDColorFrameIndex(uint32_t color32);
uint32_t GetHUDColorLagFrameCount() const;
virtual void SetHUDColorLagFrameCount(uint32_t color32);
uint32_t GetHUDColorCPULoadAverage() const;
virtual void SetHUDColorCPULoadAverage(uint32_t color32);
uint32_t GetHUDColorRTC() const;
virtual void SetHUDColorRTC(uint32_t color32);
bool HUDNeedsUpdate(); bool HUDNeedsUpdate();
void ClearHUDNeedsUpdate(); void ClearHUDNeedsUpdate();
@ -319,7 +339,8 @@ public:
virtual void SetSourceDeposterize(const bool useDeposterize); virtual void SetSourceDeposterize(const bool useDeposterize);
void SetHUDVertices(float viewportWidth, float viewportHeight, float *vtxBufferPtr); void SetHUDPositionVertices(float viewportWidth, float viewportHeight, float *vtxPositionBufferPtr);
void SetHUDColorVertices(uint32_t *vtxColorBufferPtr);
void SetHUDTextureCoordinates(float *texCoordBufferPtr); void SetHUDTextureCoordinates(float *texCoordBufferPtr);
void SetScreenVertices(float *vtxBufferPtr); void SetScreenVertices(float *vtxBufferPtr);
void SetScreenTextureCoordinates(float w0, float h0, float w1, float h1, float *texCoordBufferPtr); void SetScreenTextureCoordinates(float w0, float h0, float w1, float h1, float *texCoordBufferPtr);

View File

@ -118,6 +118,18 @@
<false/> <false/>
<key>HUD_ShowRTC</key> <key>HUD_ShowRTC</key>
<false/> <false/>
<key>HUD_Color_VideoFPS</key>
<integer>4294967295</integer>
<key>HUD_Color_Render3DFPS</key>
<integer>4294967295</integer>
<key>HUD_Color_FrameIndex</key>
<integer>4294967295</integer>
<key>HUD_Color_LagFrameCount</key>
<integer>4294967295</integer>
<key>HUD_Color_CPULoadAverage</key>
<integer>4294967295</integer>
<key>HUD_Color_RTC</key>
<integer>4294967295</integer>
<key>Input_AudioInputMode</key> <key>Input_AudioInputMode</key>
<integer>1</integer> <integer>1</integer>
<key>Input_ControllerMappings</key> <key>Input_ControllerMappings</key>

View File

@ -28,10 +28,12 @@
// VERTEX SHADER FOR HUD OUTPUT // VERTEX SHADER FOR HUD OUTPUT
static const char *HUDOutputVertShader_100 = {"\ static const char *HUDOutputVertShader_100 = {"\
ATTRIBUTE vec2 inPosition; \n\ ATTRIBUTE vec2 inPosition; \n\
ATTRIBUTE vec4 inColor; \n\
ATTRIBUTE vec2 inTexCoord0; \n\ ATTRIBUTE vec2 inTexCoord0; \n\
\n\ \n\
uniform vec2 viewSize; \n\ uniform vec2 viewSize; \n\
\n\ \n\
VARYING vec4 vtxColor; \n\
VARYING vec2 texCoord[1]; \n\ VARYING vec2 texCoord[1]; \n\
\n\ \n\
void main() \n\ void main() \n\
@ -39,6 +41,7 @@ static const char *HUDOutputVertShader_100 = {"\
mat2 projection = mat2( vec2(2.0/viewSize.x, 0.0), \n\ mat2 projection = mat2( vec2(2.0/viewSize.x, 0.0), \n\
vec2( 0.0, 2.0/viewSize.y)); \n\ vec2( 0.0, 2.0/viewSize.y)); \n\
\n\ \n\
vtxColor = inColor; \n\
texCoord[0] = inTexCoord0; \n\ texCoord[0] = inTexCoord0; \n\
gl_Position = vec4(projection * inPosition, 0.0, 1.0);\n\ gl_Position = vec4(projection * inPosition, 0.0, 1.0);\n\
} \n\ } \n\
@ -46,12 +49,13 @@ static const char *HUDOutputVertShader_100 = {"\
// FRAGMENT SHADER FOR HUD OUTPUT // FRAGMENT SHADER FOR HUD OUTPUT
static const char *HUDOutputFragShader_110 = {"\ static const char *HUDOutputFragShader_110 = {"\
VARYING vec4 vtxColor;\n\
VARYING vec2 texCoord[1];\n\ VARYING vec2 texCoord[1];\n\
uniform sampler2D tex;\n\ uniform sampler2D tex;\n\
\n\ \n\
void main()\n\ void main()\n\
{\n\ {\n\
OUT_FRAG_COLOR = SAMPLE4_TEX_2D(tex, texCoord[0]);\n\ OUT_FRAG_COLOR = SAMPLE4_TEX_2D(tex, texCoord[0]) * vtxColor;\n\
}\n\ }\n\
"}; "};
@ -4108,8 +4112,9 @@ static const char *Scaler6xBRZFragShader_110 = {"\
enum OGLVertexAttributeID enum OGLVertexAttributeID
{ {
OGLVertexAttributeID_Position = 0, OGLVertexAttributeID_Position = 0,
OGLVertexAttributeID_TexCoord0 = 8 OGLVertexAttributeID_TexCoord0 = 8,
OGLVertexAttributeID_Color = 3
}; };
static const GLint filterVtxBuffer[8] = {-1, -1, 1, -1, -1, 1, 1, 1}; static const GLint filterVtxBuffer[8] = {-1, -1, 1, -1, -1, 1, 1, 1};
@ -4594,7 +4599,7 @@ GLuint OGLShaderProgram::GetVertexShaderID()
return this->_vertexID; return this->_vertexID;
} }
void OGLShaderProgram::SetVertexShaderOGL(const char *shaderProgram, bool useShader150) void OGLShaderProgram::SetVertexShaderOGL(const char *shaderProgram, bool useVtxColors, bool useShader150)
{ {
if (this->_vertexID != 0) if (this->_vertexID != 0)
{ {
@ -4609,6 +4614,11 @@ void OGLShaderProgram::SetVertexShaderOGL(const char *shaderProgram, bool useSha
glAttachShader(this->_programID, this->_vertexID); glAttachShader(this->_programID, this->_vertexID);
glBindAttribLocation(this->_programID, OGLVertexAttributeID_Position, "inPosition"); glBindAttribLocation(this->_programID, OGLVertexAttributeID_Position, "inPosition");
glBindAttribLocation(this->_programID, OGLVertexAttributeID_TexCoord0, "inTexCoord0"); glBindAttribLocation(this->_programID, OGLVertexAttributeID_TexCoord0, "inTexCoord0");
if (useVtxColors)
{
glBindAttribLocation(this->_programID, OGLVertexAttributeID_Color, "inColor");
}
} }
if (this->_vertexID != 0 && this->_fragmentID != 0) if (this->_vertexID != 0 && this->_fragmentID != 0)
@ -4647,7 +4657,7 @@ void OGLShaderProgram::SetFragmentShaderOGL(const char *shaderProgram, bool useS
} }
} }
void OGLShaderProgram::SetVertexAndFragmentShaderOGL(const char *vertShaderProgram, const char *fragShaderProgram, bool useShader150) void OGLShaderProgram::SetVertexAndFragmentShaderOGL(const char *vertShaderProgram, const char *fragShaderProgram, bool useVtxColors, bool useShader150)
{ {
if (this->_vertexID != 0) if (this->_vertexID != 0)
{ {
@ -4669,6 +4679,11 @@ void OGLShaderProgram::SetVertexAndFragmentShaderOGL(const char *vertShaderProgr
glAttachShader(this->_programID, this->_vertexID); glAttachShader(this->_programID, this->_vertexID);
glBindAttribLocation(this->_programID, OGLVertexAttributeID_Position, "inPosition"); glBindAttribLocation(this->_programID, OGLVertexAttributeID_Position, "inPosition");
glBindAttribLocation(this->_programID, OGLVertexAttributeID_TexCoord0, "inTexCoord0"); glBindAttribLocation(this->_programID, OGLVertexAttributeID_TexCoord0, "inTexCoord0");
if (useVtxColors)
{
glBindAttribLocation(this->_programID, OGLVertexAttributeID_Color, "inColor");
}
} }
if (this->_fragmentID != 0) if (this->_fragmentID != 0)
@ -5442,7 +5457,7 @@ OGLFilterDeposterize::OGLFilterDeposterize(GLsizei srcWidth, GLsizei srcHeight,
glBindTexture(GL_TEXTURE_RECTANGLE_ARB, 0); glBindTexture(GL_TEXTURE_RECTANGLE_ARB, 0);
_program->SetShaderSupport(theTier); _program->SetShaderSupport(theTier);
_program->SetVertexShaderOGL(Sample3x3_VertShader_110, useShader150); _program->SetVertexShaderOGL(Sample3x3_VertShader_110, false, useShader150);
_program->SetFragmentShaderOGL(FilterDeposterizeFragShader_110, useShader150); _program->SetFragmentShaderOGL(FilterDeposterizeFragShader_110, useShader150);
} }
@ -5595,7 +5610,7 @@ OGLImage::OGLImage(OGLContextInfo *contextInfo, GLsizei imageWidth, GLsizei imag
{ {
_finalOutputProgram = new OGLShaderProgram; _finalOutputProgram = new OGLShaderProgram;
_finalOutputProgram->SetShaderSupport(_shaderSupport); _finalOutputProgram->SetShaderSupport(_shaderSupport);
_finalOutputProgram->SetVertexAndFragmentShaderOGL(Sample1x1OutputVertShader_100, PassthroughOutputFragShader_110, _useShader150); _finalOutputProgram->SetVertexAndFragmentShaderOGL(Sample1x1OutputVertShader_100, PassthroughOutputFragShader_110, false, _useShader150);
const GLuint finalOutputProgramID = _finalOutputProgram->GetProgramID(); const GLuint finalOutputProgramID = _finalOutputProgram->GetProgramID();
glUseProgram(finalOutputProgramID); glUseProgram(finalOutputProgramID);
@ -5617,7 +5632,7 @@ OGLImage::OGLImage(OGLContextInfo *contextInfo, GLsizei imageWidth, GLsizei imag
_shaderFilter = new OGLFilter(_vf->GetSrcWidth(), _vf->GetSrcHeight(), 1); _shaderFilter = new OGLFilter(_vf->GetSrcWidth(), _vf->GetSrcHeight(), 1);
OGLShaderProgram *shaderFilterProgram = _shaderFilter->GetProgram(); OGLShaderProgram *shaderFilterProgram = _shaderFilter->GetProgram();
shaderFilterProgram->SetShaderSupport(_shaderSupport); shaderFilterProgram->SetShaderSupport(_shaderSupport);
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample1x1_VertShader_110, PassthroughFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample1x1_VertShader_110, PassthroughFragShader_110, false, _useShader150);
SetupHQnxLUTs_OGL(GL_TEXTURE0 + 1, _texLQ2xLUT, _texHQ2xLUT, _texHQ3xLUT, _texHQ4xLUT); SetupHQnxLUTs_OGL(GL_TEXTURE0 + 1, _texLQ2xLUT, _texHQ2xLUT, _texHQ3xLUT, _texHQ4xLUT);
} }
@ -5773,45 +5788,45 @@ void OGLImage::SetOutputFilterOGL(const int filterID)
switch (filterID) switch (filterID)
{ {
case OutputFilterTypeID_NearestNeighbor: case OutputFilterTypeID_NearestNeighbor:
this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(Sample1x1OutputVertShader_100, PassthroughOutputFragShader_110, _useShader150); this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(Sample1x1OutputVertShader_100, PassthroughOutputFragShader_110, false, _useShader150);
break; break;
case OutputFilterTypeID_Bilinear: case OutputFilterTypeID_Bilinear:
this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(Sample1x1OutputVertShader_100, PassthroughOutputFragShader_110, _useShader150); this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(Sample1x1OutputVertShader_100, PassthroughOutputFragShader_110, false, _useShader150);
this->_displayTexFilter = GL_LINEAR; this->_displayTexFilter = GL_LINEAR;
break; break;
case OutputFilterTypeID_BicubicBSpline: case OutputFilterTypeID_BicubicBSpline:
this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample4x4Output_VertShader_110, FilterBicubicBSplineFragShader_110, _useShader150); this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample4x4Output_VertShader_110, FilterBicubicBSplineFragShader_110, false, _useShader150);
break; break;
case OutputFilterTypeID_BicubicMitchell: case OutputFilterTypeID_BicubicMitchell:
this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample4x4Output_VertShader_110, FilterBicubicMitchellNetravaliFragShader_110, _useShader150); this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample4x4Output_VertShader_110, FilterBicubicMitchellNetravaliFragShader_110, false, _useShader150);
break; break;
case OutputFilterTypeID_Lanczos2: case OutputFilterTypeID_Lanczos2:
this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample4x4Output_VertShader_110, FilterLanczos2FragShader_110, _useShader150); this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample4x4Output_VertShader_110, FilterLanczos2FragShader_110, false, _useShader150);
break; break;
case OutputFilterTypeID_Lanczos3: case OutputFilterTypeID_Lanczos3:
{ {
if (this->_shaderSupport >= ShaderSupport_HighTier) if (this->_shaderSupport >= ShaderSupport_HighTier)
{ {
this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample6x6Output_VertShader_110, FilterLanczos3FragShader_110, _useShader150); this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample6x6Output_VertShader_110, FilterLanczos3FragShader_110, false, _useShader150);
} }
else if (this->_shaderSupport >= ShaderSupport_MidTier) else if (this->_shaderSupport >= ShaderSupport_MidTier)
{ {
this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample5x5Output_VertShader_110, FilterLanczos3FragShader_110, _useShader150); this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample5x5Output_VertShader_110, FilterLanczos3FragShader_110, false, _useShader150);
} }
else else
{ {
this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample4x4Output_VertShader_110, FilterLanczos3FragShader_110, _useShader150); this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample4x4Output_VertShader_110, FilterLanczos3FragShader_110, false, _useShader150);
} }
break; break;
} }
default: default:
this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(Sample1x1OutputVertShader_100, PassthroughOutputFragShader_110, _useShader150); this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(Sample1x1OutputVertShader_100, PassthroughOutputFragShader_110, false, _useShader150);
this->_outputFilter = OutputFilterTypeID_NearestNeighbor; this->_outputFilter = OutputFilterTypeID_NearestNeighbor;
break; break;
} }
@ -5861,74 +5876,74 @@ bool OGLImage::SetGPUPixelScalerOGL(const VideoFilterTypeID filterID)
switch (filterID) switch (filterID)
{ {
case VideoFilterTypeID_Nearest1_5X: case VideoFilterTypeID_Nearest1_5X:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample1x1_VertShader_110, PassthroughFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample1x1_VertShader_110, PassthroughFragShader_110, false, _useShader150);
break; break;
case VideoFilterTypeID_Nearest2X: case VideoFilterTypeID_Nearest2X:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample1x1_VertShader_110, PassthroughFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample1x1_VertShader_110, PassthroughFragShader_110, false, _useShader150);
break; break;
case VideoFilterTypeID_Scanline: case VideoFilterTypeID_Scanline:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample1x1_VertShader_110, Scalar2xScanlineFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample1x1_VertShader_110, Scalar2xScanlineFragShader_110, false, _useShader150);
break; break;
case VideoFilterTypeID_EPX: case VideoFilterTypeID_EPX:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, Scalar2xEPXFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, Scalar2xEPXFragShader_110, false, _useShader150);
break; break;
case VideoFilterTypeID_EPXPlus: case VideoFilterTypeID_EPXPlus:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, Scalar2xEPXPlusFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, Scalar2xEPXPlusFragShader_110, false, _useShader150);
break; break;
case VideoFilterTypeID_2xSaI: case VideoFilterTypeID_2xSaI:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample4x4_VertShader_110, Scalar2xSaIFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample4x4_VertShader_110, Scalar2xSaIFragShader_110, false, _useShader150);
break; break;
case VideoFilterTypeID_Super2xSaI: case VideoFilterTypeID_Super2xSaI:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample4x4_VertShader_110, ScalarSuper2xSaIFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample4x4_VertShader_110, ScalarSuper2xSaIFragShader_110, false, _useShader150);
break; break;
case VideoFilterTypeID_SuperEagle: case VideoFilterTypeID_SuperEagle:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample4x4_VertShader_110, ScalarSuperEagle2xFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample4x4_VertShader_110, ScalarSuperEagle2xFragShader_110, false, _useShader150);
break; break;
case VideoFilterTypeID_LQ2X: case VideoFilterTypeID_LQ2X:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerLQ2xFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerLQ2xFragShader_110, false, _useShader150);
currentHQnxLUT = this->_texLQ2xLUT; currentHQnxLUT = this->_texLQ2xLUT;
break; break;
case VideoFilterTypeID_LQ2XS: case VideoFilterTypeID_LQ2XS:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerLQ2xSFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerLQ2xSFragShader_110, false, _useShader150);
currentHQnxLUT = this->_texLQ2xLUT; currentHQnxLUT = this->_texLQ2xLUT;
break; break;
case VideoFilterTypeID_HQ2X: case VideoFilterTypeID_HQ2X:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ2xFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ2xFragShader_110, false, _useShader150);
currentHQnxLUT = this->_texHQ2xLUT; currentHQnxLUT = this->_texHQ2xLUT;
break; break;
case VideoFilterTypeID_HQ2XS: case VideoFilterTypeID_HQ2XS:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ2xSFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ2xSFragShader_110, false, _useShader150);
currentHQnxLUT = this->_texHQ2xLUT; currentHQnxLUT = this->_texHQ2xLUT;
break; break;
case VideoFilterTypeID_HQ3X: case VideoFilterTypeID_HQ3X:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ3xFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ3xFragShader_110, false, _useShader150);
currentHQnxLUT = this->_texHQ3xLUT; currentHQnxLUT = this->_texHQ3xLUT;
break; break;
case VideoFilterTypeID_HQ3XS: case VideoFilterTypeID_HQ3XS:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ3xSFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ3xSFragShader_110, false, _useShader150);
currentHQnxLUT = this->_texHQ3xLUT; currentHQnxLUT = this->_texHQ3xLUT;
break; break;
case VideoFilterTypeID_HQ4X: case VideoFilterTypeID_HQ4X:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ4xFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ4xFragShader_110, false, _useShader150);
currentHQnxLUT = this->_texHQ4xLUT; currentHQnxLUT = this->_texHQ4xLUT;
break; break;
case VideoFilterTypeID_HQ4XS: case VideoFilterTypeID_HQ4XS:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ4xSFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ4xSFragShader_110, false, _useShader150);
currentHQnxLUT = this->_texHQ4xLUT; currentHQnxLUT = this->_texHQ4xLUT;
break; break;
@ -5936,11 +5951,11 @@ bool OGLImage::SetGPUPixelScalerOGL(const VideoFilterTypeID filterID)
{ {
if (this->_shaderSupport >= ShaderSupport_MidTier) if (this->_shaderSupport >= ShaderSupport_MidTier)
{ {
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample5x5_VertShader_110, Scaler2xBRZFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample5x5_VertShader_110, Scaler2xBRZFragShader_110, false, _useShader150);
} }
else if (this->_shaderSupport >= ShaderSupport_LowTier) else if (this->_shaderSupport >= ShaderSupport_LowTier)
{ {
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample4x4_VertShader_110, Scaler2xBRZFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample4x4_VertShader_110, Scaler2xBRZFragShader_110, false, _useShader150);
} }
else else
{ {
@ -5953,11 +5968,11 @@ bool OGLImage::SetGPUPixelScalerOGL(const VideoFilterTypeID filterID)
{ {
if (this->_shaderSupport >= ShaderSupport_MidTier) if (this->_shaderSupport >= ShaderSupport_MidTier)
{ {
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample5x5_VertShader_110, Scaler3xBRZFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample5x5_VertShader_110, Scaler3xBRZFragShader_110, false, _useShader150);
} }
else if (this->_shaderSupport >= ShaderSupport_LowTier) else if (this->_shaderSupport >= ShaderSupport_LowTier)
{ {
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample4x4_VertShader_110, Scaler3xBRZFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample4x4_VertShader_110, Scaler3xBRZFragShader_110, false, _useShader150);
} }
else else
{ {
@ -5970,7 +5985,7 @@ bool OGLImage::SetGPUPixelScalerOGL(const VideoFilterTypeID filterID)
{ {
if (this->_shaderSupport >= ShaderSupport_MidTier) if (this->_shaderSupport >= ShaderSupport_MidTier)
{ {
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample5x5_VertShader_110, Scaler4xBRZFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample5x5_VertShader_110, Scaler4xBRZFragShader_110, false, _useShader150);
} }
else else
{ {
@ -5984,7 +5999,7 @@ bool OGLImage::SetGPUPixelScalerOGL(const VideoFilterTypeID filterID)
{ {
if (this->_shaderSupport >= ShaderSupport_MidTier) if (this->_shaderSupport >= ShaderSupport_MidTier)
{ {
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample5x5_VertShader_110, Scaler5xBRZFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample5x5_VertShader_110, Scaler5xBRZFragShader_110, false, _useShader150);
} }
else else
{ {
@ -5997,7 +6012,7 @@ bool OGLImage::SetGPUPixelScalerOGL(const VideoFilterTypeID filterID)
{ {
if (this->_shaderSupport >= ShaderSupport_MidTier) if (this->_shaderSupport >= ShaderSupport_MidTier)
{ {
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample5x5_VertShader_110, Scaler6xBRZFragShader_110, _useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample5x5_VertShader_110, Scaler6xBRZFragShader_110, false, _useShader150);
} }
else else
{ {
@ -6187,7 +6202,7 @@ OGLHUDLayer::OGLHUDLayer(OGLVideoOutput *oglVO)
{ {
_program = new OGLShaderProgram; _program = new OGLShaderProgram;
_program->SetShaderSupport(oglVO->GetContextInfo()->GetShaderSupport()); _program->SetShaderSupport(oglVO->GetContextInfo()->GetShaderSupport());
_program->SetVertexAndFragmentShaderOGL(HUDOutputVertShader_100, HUDOutputFragShader_110, oglVO->GetContextInfo()->IsUsingShader150()); _program->SetVertexAndFragmentShaderOGL(HUDOutputVertShader_100, HUDOutputFragShader_110, true, oglVO->GetContextInfo()->IsUsingShader150());
glUseProgram(_program->GetProgramID()); glUseProgram(_program->GetProgramID());
_uniformViewSize = glGetUniformLocation(_program->GetProgramID(), "viewSize"); _uniformViewSize = glGetUniformLocation(_program->GetProgramID(), "viewSize");
@ -6201,12 +6216,15 @@ OGLHUDLayer::OGLHUDLayer(OGLVideoOutput *oglVO)
glGenTextures(1, &_texCharMap); glGenTextures(1, &_texCharMap);
// Set up VBOs // Set up VBOs
glGenBuffersARB(1, &_vboVertexID); glGenBuffersARB(1, &_vboPositionVertexID);
glGenBuffersARB(1, &_vboColorVertexID);
glGenBuffersARB(1, &_vboTexCoordID); glGenBuffersARB(1, &_vboTexCoordID);
glGenBuffersARB(1, &_vboElementID); glGenBuffersARB(1, &_vboElementID);
glBindBufferARB(GL_ARRAY_BUFFER_ARB, _vboVertexID); glBindBufferARB(GL_ARRAY_BUFFER_ARB, _vboPositionVertexID);
glBufferDataARB(GL_ARRAY_BUFFER_ARB, HUD_VERTEX_ATTRIBUTE_BUFFER_SIZE, NULL, GL_STREAM_DRAW_ARB); glBufferDataARB(GL_ARRAY_BUFFER_ARB, HUD_VERTEX_ATTRIBUTE_BUFFER_SIZE, NULL, GL_STREAM_DRAW_ARB);
glBindBufferARB(GL_ARRAY_BUFFER_ARB, _vboColorVertexID);
glBufferDataARB(GL_ARRAY_BUFFER_ARB, HUD_VERTEX_COLOR_ATTRIBUTE_BUFFER_SIZE, NULL, GL_STREAM_DRAW_ARB);
glBindBufferARB(GL_ARRAY_BUFFER_ARB, _vboTexCoordID); glBindBufferARB(GL_ARRAY_BUFFER_ARB, _vboTexCoordID);
glBufferDataARB(GL_ARRAY_BUFFER_ARB, HUD_VERTEX_ATTRIBUTE_BUFFER_SIZE, NULL, GL_STREAM_DRAW_ARB); glBufferDataARB(GL_ARRAY_BUFFER_ARB, HUD_VERTEX_ATTRIBUTE_BUFFER_SIZE, NULL, GL_STREAM_DRAW_ARB);
glBindBufferARB(GL_ARRAY_BUFFER_ARB, 0); glBindBufferARB(GL_ARRAY_BUFFER_ARB, 0);
@ -6234,24 +6252,30 @@ OGLHUDLayer::OGLHUDLayer(OGLVideoOutput *oglVO)
if (oglVO->GetContextInfo()->IsShaderSupported()) if (oglVO->GetContextInfo()->IsShaderSupported())
{ {
glBindBufferARB(GL_ARRAY_BUFFER_ARB, _vboVertexID); glBindBufferARB(GL_ARRAY_BUFFER_ARB, _vboPositionVertexID);
glVertexAttribPointer(OGLVertexAttributeID_Position, 2, GL_FLOAT, GL_FALSE, 0, NULL); glVertexAttribPointer(OGLVertexAttributeID_Position, 2, GL_FLOAT, GL_FALSE, 0, NULL);
glBindBufferARB(GL_ARRAY_BUFFER_ARB, _vboColorVertexID);
glVertexAttribPointer(OGLVertexAttributeID_Color, 4, GL_UNSIGNED_BYTE, GL_TRUE, 0, NULL);
glBindBufferARB(GL_ARRAY_BUFFER_ARB, _vboTexCoordID); glBindBufferARB(GL_ARRAY_BUFFER_ARB, _vboTexCoordID);
glVertexAttribPointer(OGLVertexAttributeID_TexCoord0, 2, GL_FLOAT, GL_FALSE, 0, NULL); glVertexAttribPointer(OGLVertexAttributeID_TexCoord0, 2, GL_FLOAT, GL_FALSE, 0, NULL);
glBindBufferARB(GL_ELEMENT_ARRAY_BUFFER_ARB, _vboElementID); glBindBufferARB(GL_ELEMENT_ARRAY_BUFFER_ARB, _vboElementID);
glEnableVertexAttribArray(OGLVertexAttributeID_Position); glEnableVertexAttribArray(OGLVertexAttributeID_Position);
glEnableVertexAttribArray(OGLVertexAttributeID_Color);
glEnableVertexAttribArray(OGLVertexAttributeID_TexCoord0); glEnableVertexAttribArray(OGLVertexAttributeID_TexCoord0);
} }
else else
{ {
glBindBufferARB(GL_ARRAY_BUFFER_ARB, _vboVertexID); glBindBufferARB(GL_ARRAY_BUFFER_ARB, _vboPositionVertexID);
glVertexPointer(2, GL_FLOAT, 0, NULL); glVertexPointer(2, GL_FLOAT, 0, NULL);
glBindBufferARB(GL_ARRAY_BUFFER_ARB, _vboColorVertexID);
glColorPointer(4, GL_UNSIGNED_BYTE, 0, NULL);
glBindBufferARB(GL_ARRAY_BUFFER_ARB, _vboTexCoordID); glBindBufferARB(GL_ARRAY_BUFFER_ARB, _vboTexCoordID);
glTexCoordPointer(2, GL_FLOAT, 0, NULL); glTexCoordPointer(2, GL_FLOAT, 0, NULL);
glBindBufferARB(GL_ELEMENT_ARRAY_BUFFER_ARB, _vboElementID); glBindBufferARB(GL_ELEMENT_ARRAY_BUFFER_ARB, _vboElementID);
glEnableClientState(GL_VERTEX_ARRAY); glEnableClientState(GL_VERTEX_ARRAY);
glEnableClientState(GL_COLOR_ARRAY);
glEnableClientState(GL_TEXTURE_COORD_ARRAY); glEnableClientState(GL_TEXTURE_COORD_ARRAY);
} }
@ -6267,7 +6291,8 @@ OGLHUDLayer::~OGLHUDLayer()
} }
glDeleteVertexArraysDESMUME(1, &this->_vaoMainStatesID); glDeleteVertexArraysDESMUME(1, &this->_vaoMainStatesID);
glDeleteBuffersARB(1, &this->_vboVertexID); glDeleteBuffersARB(1, &this->_vboPositionVertexID);
glDeleteBuffersARB(1, &this->_vboColorVertexID);
glDeleteBuffersARB(1, &this->_vboTexCoordID); glDeleteBuffersARB(1, &this->_vboTexCoordID);
glDeleteBuffersARB(1, &this->_vboElementID); glDeleteBuffersARB(1, &this->_vboElementID);
@ -6310,7 +6335,7 @@ void OGLHUDLayer::CopyHUDFont(const FT_Face &fontFace, const size_t glyphSize, c
{ {
for (size_t pixIndex = 0; pixIndex < tileSize; pixIndex++) for (size_t pixIndex = 0; pixIndex < tileSize; pixIndex++)
{ {
const uint32_t colorRGBA8888 = 0x50000000; const uint32_t colorRGBA8888 = 0xFFFFFFFF;
charMapBuffer[(tileSize + pixIndex) + (rowIndex * (16 * tileSize))] = colorRGBA8888; charMapBuffer[(tileSize + pixIndex) + (rowIndex * (16 * tileSize))] = colorRGBA8888;
} }
} }
@ -6368,10 +6393,16 @@ void OGLHUDLayer::_UpdateVerticesOGL()
return; return;
} }
glBindBufferARB(GL_ARRAY_BUFFER_ARB, this->_vboVertexID); glBindBufferARB(GL_ARRAY_BUFFER_ARB, this->_vboPositionVertexID);
glBufferDataARB(GL_ARRAY_BUFFER_ARB, HUD_VERTEX_ATTRIBUTE_BUFFER_SIZE, NULL, GL_STREAM_DRAW_ARB); glBufferDataARB(GL_ARRAY_BUFFER_ARB, HUD_VERTEX_ATTRIBUTE_BUFFER_SIZE, NULL, GL_STREAM_DRAW_ARB);
float *vtxBufferPtr = (float *)glMapBufferARB(GL_ARRAY_BUFFER_ARB, GL_WRITE_ONLY_ARB); float *vtxPositionBufferPtr = (float *)glMapBufferARB(GL_ARRAY_BUFFER_ARB, GL_WRITE_ONLY_ARB);
this->_output->SetHUDVertices((float)this->_output->GetViewportWidth(), (float)this->_output->GetViewportHeight(), vtxBufferPtr); this->_output->SetHUDPositionVertices((float)this->_output->GetViewportWidth(), (float)this->_output->GetViewportHeight(), vtxPositionBufferPtr);
glUnmapBufferARB(GL_ARRAY_BUFFER_ARB);
glBindBufferARB(GL_ARRAY_BUFFER_ARB, this->_vboColorVertexID);
glBufferDataARB(GL_ARRAY_BUFFER_ARB, HUD_VERTEX_COLOR_ATTRIBUTE_BUFFER_SIZE, NULL, GL_STREAM_DRAW_ARB);
uint32_t *vtxColorBufferPtr = (uint32_t *)glMapBufferARB(GL_ARRAY_BUFFER_ARB, GL_WRITE_ONLY_ARB);
this->_output->SetHUDColorVertices(vtxColorBufferPtr);
glUnmapBufferARB(GL_ARRAY_BUFFER_ARB); glUnmapBufferARB(GL_ARRAY_BUFFER_ARB);
glBindBufferARB(GL_ARRAY_BUFFER_ARB, this->_vboTexCoordID); glBindBufferARB(GL_ARRAY_BUFFER_ARB, this->_vboTexCoordID);
@ -6496,7 +6527,7 @@ OGLDisplayLayer::OGLDisplayLayer(OGLVideoOutput *oglVO)
{ {
_finalOutputProgram = new OGLShaderProgram; _finalOutputProgram = new OGLShaderProgram;
_finalOutputProgram->SetShaderSupport(shaderSupport); _finalOutputProgram->SetShaderSupport(shaderSupport);
_finalOutputProgram->SetVertexAndFragmentShaderOGL(Sample1x1OutputVertShader_100, PassthroughOutputFragShader_110, useShader150); _finalOutputProgram->SetVertexAndFragmentShaderOGL(Sample1x1OutputVertShader_100, PassthroughOutputFragShader_110, false, useShader150);
const GLuint finalOutputProgramID = _finalOutputProgram->GetProgramID(); const GLuint finalOutputProgramID = _finalOutputProgram->GetProgramID();
glUseProgram(finalOutputProgramID); glUseProgram(finalOutputProgramID);
@ -6519,7 +6550,7 @@ OGLDisplayLayer::OGLDisplayLayer(OGLVideoOutput *oglVO)
_shaderFilter[i] = new OGLFilter(GPU_FRAMEBUFFER_NATIVE_WIDTH, GPU_FRAMEBUFFER_NATIVE_HEIGHT, 1); _shaderFilter[i] = new OGLFilter(GPU_FRAMEBUFFER_NATIVE_WIDTH, GPU_FRAMEBUFFER_NATIVE_HEIGHT, 1);
OGLShaderProgram *shaderFilterProgram = _shaderFilter[i]->GetProgram(); OGLShaderProgram *shaderFilterProgram = _shaderFilter[i]->GetProgram();
shaderFilterProgram->SetShaderSupport(shaderSupport); shaderFilterProgram->SetShaderSupport(shaderSupport);
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample1x1_VertShader_110, PassthroughFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample1x1_VertShader_110, PassthroughFragShader_110, false, useShader150);
} }
} }
else else
@ -6614,46 +6645,46 @@ OutputFilterTypeID OGLDisplayLayer::SetOutputFilterOGL(const OutputFilterTypeID
switch (filterID) switch (filterID)
{ {
case OutputFilterTypeID_NearestNeighbor: case OutputFilterTypeID_NearestNeighbor:
this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(Sample1x1OutputVertShader_100, PassthroughOutputFragShader_110, useShader150); this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(Sample1x1OutputVertShader_100, PassthroughOutputFragShader_110, false, useShader150);
break; break;
case OutputFilterTypeID_Bilinear: case OutputFilterTypeID_Bilinear:
this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(Sample1x1OutputVertShader_100, PassthroughOutputFragShader_110, useShader150); this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(Sample1x1OutputVertShader_100, PassthroughOutputFragShader_110, false, useShader150);
this->_displayTexFilter[0] = GL_LINEAR; this->_displayTexFilter[0] = GL_LINEAR;
this->_displayTexFilter[1] = GL_LINEAR; this->_displayTexFilter[1] = GL_LINEAR;
break; break;
case OutputFilterTypeID_BicubicBSpline: case OutputFilterTypeID_BicubicBSpline:
this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample4x4Output_VertShader_110, FilterBicubicBSplineFragShader_110, useShader150); this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample4x4Output_VertShader_110, FilterBicubicBSplineFragShader_110, false, useShader150);
break; break;
case OutputFilterTypeID_BicubicMitchell: case OutputFilterTypeID_BicubicMitchell:
this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample4x4Output_VertShader_110, FilterBicubicMitchellNetravaliFragShader_110, useShader150); this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample4x4Output_VertShader_110, FilterBicubicMitchellNetravaliFragShader_110, false, useShader150);
break; break;
case OutputFilterTypeID_Lanczos2: case OutputFilterTypeID_Lanczos2:
this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample4x4Output_VertShader_110, FilterLanczos2FragShader_110, useShader150); this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample4x4Output_VertShader_110, FilterLanczos2FragShader_110, false, useShader150);
break; break;
case OutputFilterTypeID_Lanczos3: case OutputFilterTypeID_Lanczos3:
{ {
if (shaderSupport >= ShaderSupport_HighTier) if (shaderSupport >= ShaderSupport_HighTier)
{ {
this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample6x6Output_VertShader_110, FilterLanczos3FragShader_110, useShader150); this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample6x6Output_VertShader_110, FilterLanczos3FragShader_110, false, useShader150);
} }
else if (shaderSupport >= ShaderSupport_MidTier) else if (shaderSupport >= ShaderSupport_MidTier)
{ {
this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample5x5Output_VertShader_110, FilterLanczos3FragShader_110, useShader150); this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample5x5Output_VertShader_110, FilterLanczos3FragShader_110, false, useShader150);
} }
else else
{ {
this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample4x4Output_VertShader_110, FilterLanczos3FragShader_110, useShader150); this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(BicubicSample4x4Output_VertShader_110, FilterLanczos3FragShader_110, false, useShader150);
} }
break; break;
} }
default: default:
this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(Sample1x1OutputVertShader_100, PassthroughOutputFragShader_110, useShader150); this->_finalOutputProgram->SetVertexAndFragmentShaderOGL(Sample1x1OutputVertShader_100, PassthroughOutputFragShader_110, false, useShader150);
outputFilter = OutputFilterTypeID_NearestNeighbor; outputFilter = OutputFilterTypeID_NearestNeighbor;
break; break;
} }
@ -6691,74 +6722,74 @@ bool OGLDisplayLayer::SetGPUPixelScalerOGL(const VideoFilterTypeID filterID)
switch (filterID) switch (filterID)
{ {
case VideoFilterTypeID_Nearest1_5X: case VideoFilterTypeID_Nearest1_5X:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample1x1_VertShader_110, PassthroughFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample1x1_VertShader_110, PassthroughFragShader_110, false, useShader150);
break; break;
case VideoFilterTypeID_Nearest2X: case VideoFilterTypeID_Nearest2X:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample1x1_VertShader_110, PassthroughFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample1x1_VertShader_110, PassthroughFragShader_110, false, useShader150);
break; break;
case VideoFilterTypeID_Scanline: case VideoFilterTypeID_Scanline:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample1x1_VertShader_110, Scalar2xScanlineFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample1x1_VertShader_110, Scalar2xScanlineFragShader_110, false, useShader150);
break; break;
case VideoFilterTypeID_EPX: case VideoFilterTypeID_EPX:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, Scalar2xEPXFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, Scalar2xEPXFragShader_110, false, useShader150);
break; break;
case VideoFilterTypeID_EPXPlus: case VideoFilterTypeID_EPXPlus:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, Scalar2xEPXPlusFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, Scalar2xEPXPlusFragShader_110, false, useShader150);
break; break;
case VideoFilterTypeID_2xSaI: case VideoFilterTypeID_2xSaI:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample4x4_VertShader_110, Scalar2xSaIFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample4x4_VertShader_110, Scalar2xSaIFragShader_110, false, useShader150);
break; break;
case VideoFilterTypeID_Super2xSaI: case VideoFilterTypeID_Super2xSaI:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample4x4_VertShader_110, ScalarSuper2xSaIFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample4x4_VertShader_110, ScalarSuper2xSaIFragShader_110, false, useShader150);
break; break;
case VideoFilterTypeID_SuperEagle: case VideoFilterTypeID_SuperEagle:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample4x4_VertShader_110, ScalarSuperEagle2xFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample4x4_VertShader_110, ScalarSuperEagle2xFragShader_110, false, useShader150);
break; break;
case VideoFilterTypeID_LQ2X: case VideoFilterTypeID_LQ2X:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerLQ2xFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerLQ2xFragShader_110, false, useShader150);
currentHQnxLUT = ((const OGLClientFetchObject &)this->_output->GetFetchObject()).GetTexLQ2xLUT(); currentHQnxLUT = ((const OGLClientFetchObject &)this->_output->GetFetchObject()).GetTexLQ2xLUT();
break; break;
case VideoFilterTypeID_LQ2XS: case VideoFilterTypeID_LQ2XS:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerLQ2xSFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerLQ2xSFragShader_110, false, useShader150);
currentHQnxLUT = ((const OGLClientFetchObject &)this->_output->GetFetchObject()).GetTexLQ2xLUT(); currentHQnxLUT = ((const OGLClientFetchObject &)this->_output->GetFetchObject()).GetTexLQ2xLUT();
break; break;
case VideoFilterTypeID_HQ2X: case VideoFilterTypeID_HQ2X:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ2xFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ2xFragShader_110, false, useShader150);
currentHQnxLUT = ((const OGLClientFetchObject &)this->_output->GetFetchObject()).GetTexHQ2xLUT(); currentHQnxLUT = ((const OGLClientFetchObject &)this->_output->GetFetchObject()).GetTexHQ2xLUT();
break; break;
case VideoFilterTypeID_HQ2XS: case VideoFilterTypeID_HQ2XS:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ2xSFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ2xSFragShader_110, false, useShader150);
currentHQnxLUT = ((const OGLClientFetchObject &)this->_output->GetFetchObject()).GetTexHQ2xLUT(); currentHQnxLUT = ((const OGLClientFetchObject &)this->_output->GetFetchObject()).GetTexHQ2xLUT();
break; break;
case VideoFilterTypeID_HQ3X: case VideoFilterTypeID_HQ3X:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ3xFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ3xFragShader_110, false, useShader150);
currentHQnxLUT = ((const OGLClientFetchObject &)this->_output->GetFetchObject()).GetTexHQ3xLUT(); currentHQnxLUT = ((const OGLClientFetchObject &)this->_output->GetFetchObject()).GetTexHQ3xLUT();
break; break;
case VideoFilterTypeID_HQ3XS: case VideoFilterTypeID_HQ3XS:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ3xSFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ3xSFragShader_110, false, useShader150);
currentHQnxLUT = ((const OGLClientFetchObject &)this->_output->GetFetchObject()).GetTexHQ3xLUT(); currentHQnxLUT = ((const OGLClientFetchObject &)this->_output->GetFetchObject()).GetTexHQ3xLUT();
break; break;
case VideoFilterTypeID_HQ4X: case VideoFilterTypeID_HQ4X:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ4xFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ4xFragShader_110, false, useShader150);
currentHQnxLUT = ((const OGLClientFetchObject &)this->_output->GetFetchObject()).GetTexHQ4xLUT(); currentHQnxLUT = ((const OGLClientFetchObject &)this->_output->GetFetchObject()).GetTexHQ4xLUT();
break; break;
case VideoFilterTypeID_HQ4XS: case VideoFilterTypeID_HQ4XS:
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ4xSFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample3x3_VertShader_110, ScalerHQ4xSFragShader_110, false, useShader150);
currentHQnxLUT = ((const OGLClientFetchObject &)this->_output->GetFetchObject()).GetTexHQ4xLUT(); currentHQnxLUT = ((const OGLClientFetchObject &)this->_output->GetFetchObject()).GetTexHQ4xLUT();
break; break;
@ -6766,11 +6797,11 @@ bool OGLDisplayLayer::SetGPUPixelScalerOGL(const VideoFilterTypeID filterID)
{ {
if (shaderSupport >= ShaderSupport_MidTier) if (shaderSupport >= ShaderSupport_MidTier)
{ {
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample5x5_VertShader_110, Scaler2xBRZFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample5x5_VertShader_110, Scaler2xBRZFragShader_110, false, useShader150);
} }
else if (shaderSupport >= ShaderSupport_LowTier) else if (shaderSupport >= ShaderSupport_LowTier)
{ {
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample4x4_VertShader_110, Scaler2xBRZFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample4x4_VertShader_110, Scaler2xBRZFragShader_110, false, useShader150);
} }
else else
{ {
@ -6783,11 +6814,11 @@ bool OGLDisplayLayer::SetGPUPixelScalerOGL(const VideoFilterTypeID filterID)
{ {
if (shaderSupport >= ShaderSupport_MidTier) if (shaderSupport >= ShaderSupport_MidTier)
{ {
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample5x5_VertShader_110, Scaler3xBRZFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample5x5_VertShader_110, Scaler3xBRZFragShader_110, false, useShader150);
} }
else if (shaderSupport >= ShaderSupport_LowTier) else if (shaderSupport >= ShaderSupport_LowTier)
{ {
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample4x4_VertShader_110, Scaler3xBRZFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample4x4_VertShader_110, Scaler3xBRZFragShader_110, false, useShader150);
} }
else else
{ {
@ -6800,7 +6831,7 @@ bool OGLDisplayLayer::SetGPUPixelScalerOGL(const VideoFilterTypeID filterID)
{ {
if (shaderSupport >= ShaderSupport_MidTier) if (shaderSupport >= ShaderSupport_MidTier)
{ {
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample5x5_VertShader_110, Scaler4xBRZFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample5x5_VertShader_110, Scaler4xBRZFragShader_110, false, useShader150);
} }
else else
{ {
@ -6813,7 +6844,7 @@ bool OGLDisplayLayer::SetGPUPixelScalerOGL(const VideoFilterTypeID filterID)
{ {
if (shaderSupport >= ShaderSupport_MidTier) if (shaderSupport >= ShaderSupport_MidTier)
{ {
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample5x5_VertShader_110, Scaler5xBRZFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample5x5_VertShader_110, Scaler5xBRZFragShader_110, false, useShader150);
} }
else else
{ {
@ -6826,7 +6857,7 @@ bool OGLDisplayLayer::SetGPUPixelScalerOGL(const VideoFilterTypeID filterID)
{ {
if (shaderSupport >= ShaderSupport_MidTier) if (shaderSupport >= ShaderSupport_MidTier)
{ {
shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample5x5_VertShader_110, Scaler6xBRZFragShader_110, useShader150); shaderFilterProgram->SetVertexAndFragmentShaderOGL(Sample5x5_VertShader_110, Scaler6xBRZFragShader_110, false, useShader150);
} }
else else
{ {

View File

@ -106,10 +106,10 @@ public:
ShaderSupportTier GetShaderSupport(); ShaderSupportTier GetShaderSupport();
void SetShaderSupport(const ShaderSupportTier theTier); void SetShaderSupport(const ShaderSupportTier theTier);
GLuint GetVertexShaderID(); GLuint GetVertexShaderID();
void SetVertexShaderOGL(const char *shaderProgram, bool useShader150); void SetVertexShaderOGL(const char *shaderProgram, bool useVtxColors, bool useShader150);
GLuint GetFragmentShaderID(); GLuint GetFragmentShaderID();
void SetFragmentShaderOGL(const char *shaderProgram, bool useShader150); void SetFragmentShaderOGL(const char *shaderProgram, bool useShader150);
void SetVertexAndFragmentShaderOGL(const char *vertShaderProgram, const char *fragShaderProgram, bool useShader150); void SetVertexAndFragmentShaderOGL(const char *vertShaderProgram, const char *fragShaderProgram, bool useVtxColors, bool useShader150);
GLuint GetProgramID(); GLuint GetProgramID();
}; };
@ -274,7 +274,8 @@ protected:
GLint _uniformViewSize; GLint _uniformViewSize;
GLuint _vaoMainStatesID; GLuint _vaoMainStatesID;
GLuint _vboVertexID; GLuint _vboPositionVertexID;
GLuint _vboColorVertexID;
GLuint _vboTexCoordID; GLuint _vboTexCoordID;
GLuint _vboElementID; GLuint _vboElementID;
GLuint _texCharMap; GLuint _texCharMap;

View File

@ -148,6 +148,12 @@
@property (assign) BOOL isHUDLagFrameCountVisible; @property (assign) BOOL isHUDLagFrameCountVisible;
@property (assign) BOOL isHUDCPULoadAverageVisible; @property (assign) BOOL isHUDCPULoadAverageVisible;
@property (assign) BOOL isHUDRealTimeClockVisible; @property (assign) BOOL isHUDRealTimeClockVisible;
@property (assign) uint32_t hudColorVideoFPS;
@property (assign) uint32_t hudColorRender3DFPS;
@property (assign) uint32_t hudColorFrameIndex;
@property (assign) uint32_t hudColorLagFrameCount;
@property (assign) uint32_t hudColorCPULoadAverage;
@property (assign) uint32_t hudColorRTC;
@property (assign) NSInteger displayMainVideoSource; @property (assign) NSInteger displayMainVideoSource;
@property (assign) NSInteger displayTouchVideoSource; @property (assign) NSInteger displayTouchVideoSource;
@property (assign) BOOL useVerticalSync; @property (assign) BOOL useVerticalSync;

View File

@ -741,6 +741,12 @@
@dynamic isHUDLagFrameCountVisible; @dynamic isHUDLagFrameCountVisible;
@dynamic isHUDCPULoadAverageVisible; @dynamic isHUDCPULoadAverageVisible;
@dynamic isHUDRealTimeClockVisible; @dynamic isHUDRealTimeClockVisible;
@dynamic hudColorVideoFPS;
@dynamic hudColorRender3DFPS;
@dynamic hudColorFrameIndex;
@dynamic hudColorLagFrameCount;
@dynamic hudColorCPULoadAverage;
@dynamic hudColorRTC;
@dynamic useVerticalSync; @dynamic useVerticalSync;
@dynamic videoFiltersPreferGPU; @dynamic videoFiltersPreferGPU;
@dynamic sourceDeposterize; @dynamic sourceDeposterize;
@ -895,6 +901,102 @@
return theState; return theState;
} }
- (void) setHudColorVideoFPS:(uint32_t)theColor
{
OSSpinLockLock(&spinlockIsHUDVisible);
_cdv->SetHUDColorVideoFPS(theColor);
OSSpinLockUnlock(&spinlockIsHUDVisible);
}
- (uint32_t) hudColorVideoFPS
{
OSSpinLockLock(&spinlockIsHUDVisible);
const uint32_t color32 = _cdv->GetHUDColorVideoFPS();
OSSpinLockUnlock(&spinlockIsHUDVisible);
return color32;
}
- (void) setHudColorRender3DFPS:(uint32_t)theColor
{
OSSpinLockLock(&spinlockIsHUDVisible);
_cdv->SetHUDColorRender3DFPS(theColor);
OSSpinLockUnlock(&spinlockIsHUDVisible);
}
- (uint32_t) hudColorRender3DFPS
{
OSSpinLockLock(&spinlockIsHUDVisible);
const uint32_t color32 = _cdv->GetHUDColorRender3DFPS();
OSSpinLockUnlock(&spinlockIsHUDVisible);
return color32;
}
- (void) setHudColorFrameIndex:(uint32_t)theColor
{
OSSpinLockLock(&spinlockIsHUDVisible);
_cdv->SetHUDColorFrameIndex(theColor);
OSSpinLockUnlock(&spinlockIsHUDVisible);
}
- (uint32_t) hudColorFrameIndex
{
OSSpinLockLock(&spinlockIsHUDVisible);
const uint32_t color32 = _cdv->GetHUDColorFrameIndex();
OSSpinLockUnlock(&spinlockIsHUDVisible);
return color32;
}
- (void) setHudColorLagFrameCount:(uint32_t)theColor
{
OSSpinLockLock(&spinlockIsHUDVisible);
_cdv->SetHUDColorLagFrameCount(theColor);
OSSpinLockUnlock(&spinlockIsHUDVisible);
}
- (uint32_t) hudColorLagFrameCount
{
OSSpinLockLock(&spinlockIsHUDVisible);
const uint32_t color32 = _cdv->GetHUDColorLagFrameCount();
OSSpinLockUnlock(&spinlockIsHUDVisible);
return color32;
}
- (void) setHudColorCPULoadAverage:(uint32_t)theColor
{
OSSpinLockLock(&spinlockIsHUDVisible);
_cdv->SetHUDColorCPULoadAverage(theColor);
OSSpinLockUnlock(&spinlockIsHUDVisible);
}
- (uint32_t) hudColorCPULoadAverage
{
OSSpinLockLock(&spinlockIsHUDVisible);
const uint32_t color32 = _cdv->GetHUDColorCPULoadAverage();
OSSpinLockUnlock(&spinlockIsHUDVisible);
return color32;
}
- (void) setHudColorRTC:(uint32_t)theColor
{
OSSpinLockLock(&spinlockIsHUDVisible);
_cdv->SetHUDColorRTC(theColor);
OSSpinLockUnlock(&spinlockIsHUDVisible);
}
- (uint32_t) hudColorRTC
{
OSSpinLockLock(&spinlockIsHUDVisible);
const uint32_t color32 = _cdv->GetHUDColorRTC();
OSSpinLockUnlock(&spinlockIsHUDVisible);
return color32;
}
- (void) setDisplayMainVideoSource:(NSInteger)displaySourceID - (void) setDisplayMainVideoSource:(NSInteger)displaySourceID
{ {
OSSpinLockLock(&spinlockDisplayVideoSource); OSSpinLockLock(&spinlockDisplayVideoSource);

View File

@ -1,6 +1,6 @@
/* /*
Copyright (C) 2011 Roger Manuel Copyright (C) 2011 Roger Manuel
Copyright (C) 2012-2013 DeSmuME team Copyright (C) 2012-2017 DeSmuME team
This file is free software: you can redistribute it and/or modify This file is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by it under the terms of the GNU General Public License as published by
@ -17,6 +17,7 @@
*/ */
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>
#import <AppKit/AppKit.h>
#include <libkern/OSAtomic.h> #include <libkern/OSAtomic.h>
#include "utilities.h" #include "utilities.h"
@ -40,6 +41,9 @@
+ (NSInteger) getIBActionSenderTag:(id)sender; + (NSInteger) getIBActionSenderTag:(id)sender;
+ (BOOL) getIBActionSenderButtonStateBool:(id)sender; + (BOOL) getIBActionSenderButtonStateBool:(id)sender;
+ (NSColor *) NSColorFromRGBA8888:(uint32_t)theColor;
+ (uint32_t) RGBA8888FromNSColor:(NSColor *)theColor;
+ (NSInteger) appVersionNumeric; + (NSInteger) appVersionNumeric;
+ (NSString *) appInternalVersionString; + (NSString *) appInternalVersionString;
+ (NSString *) appInternalNameAndVersionString; + (NSString *) appInternalNameAndVersionString;
@ -90,3 +94,8 @@
- (void)postNotificationOnMainThreadName:(NSString *)aName object:(id)anObject userInfo:(NSDictionary *)aUserInfo; - (void)postNotificationOnMainThreadName:(NSString *)aName object:(id)anObject userInfo:(NSDictionary *)aUserInfo;
@end @end
@interface RGBA8888ToNSColorValueTransformer : NSValueTransformer
{ }
@end

View File

@ -1,6 +1,6 @@
/* /*
Copyright (C) 2011 Roger Manuel Copyright (C) 2011 Roger Manuel
Copyright (C) 2012-2016 DeSmuME team Copyright (C) 2012-2017 DeSmuME team
This file is free software: you can redistribute it and/or modify This file is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by it under the terms of the GNU General Public License as published by
@ -156,6 +156,36 @@ static NSDate *distantFutureDate = [[NSDate distantFuture] retain];
return theState; return theState;
} }
+ (NSColor *) NSColorFromRGBA8888:(uint32_t)theColor
{
const CGFloat r = (CGFloat)((theColor >> 0) & 0xFF) / 255.0f;
const CGFloat g = (CGFloat)((theColor >> 8) & 0xFF) / 255.0f;
const CGFloat b = (CGFloat)((theColor >> 16) & 0xFF) / 255.0f;
const CGFloat a = (CGFloat)((theColor >> 24) & 0xFF) / 255.0f;
return [NSColor colorWithDeviceRed:r green:g blue:b alpha:a];
}
+ (uint32_t) RGBA8888FromNSColor:(NSColor *)theColor
{
if (![[theColor colorSpaceName] isEqualToString:NSDeviceRGBColorSpace])
{
theColor = [theColor colorUsingColorSpaceName:NSDeviceRGBColorSpace];
if (theColor == nil)
{
return 0x00000000;
}
}
CGFloat r, g, b, a;
[theColor getRed:&r green:&g blue:&b alpha:&a];
return (((uint32_t)(r * 255.0f)) << 0) |
(((uint32_t)(g * 255.0f)) << 8) |
(((uint32_t)(b * 255.0f)) << 16) |
(((uint32_t)(a * 255.0f)) << 24);
}
+ (NSInteger) appVersionNumeric + (NSInteger) appVersionNumeric
{ {
return (NSInteger)EMU_DESMUME_VERSION_NUMERIC(); return (NSInteger)EMU_DESMUME_VERSION_NUMERIC();
@ -352,3 +382,68 @@ static NSDate *distantFutureDate = [[NSDate distantFuture] retain];
} }
@end @end
@implementation RGBA8888ToNSColorValueTransformer
+ (Class)transformedValueClass
{
return [NSColor class];
}
+ (BOOL)allowsReverseTransformation
{
return YES;
}
- (id)transformedValue:(id)value
{
if (value == nil)
{
return nil;
}
uint32_t color32 = 0xFFFFFFFF;
if ([value respondsToSelector:@selector(unsignedIntegerValue)])
{
color32 = (uint32_t)[value unsignedIntegerValue];
}
else if ([value respondsToSelector:@selector(unsignedIntValue)])
{
color32 = (uint32_t)[value unsignedIntValue];
}
else if ([value respondsToSelector:@selector(integerValue)])
{
color32 = (uint32_t)[value integerValue];
}
else if ([value respondsToSelector:@selector(intValue)])
{
color32 = (uint32_t)[value intValue];
}
else
{
[NSException raise:NSInternalInconsistencyException format:@"Value (%@) does not respond to -unsignedIntegerValue, -unsignedIntValue, -integerValue or -intValue.", [value class]];
}
return [CocoaDSUtil NSColorFromRGBA8888:color32];
}
- (id)reverseTransformedValue:(id)value
{
uint32_t color32 = 0xFFFFFFFF;
if (value == nil)
{
return nil;
}
else if (![value isKindOfClass:[NSColor class]])
{
NSLog(@"-reverseTransformedValue is %@", [value class]);
return [NSNumber numberWithUnsignedInteger:color32];
}
color32 = [CocoaDSUtil RGBA8888FromNSColor:(NSColor *)value];
return [NSNumber numberWithUnsignedInteger:color32];
}
@end

View File

@ -58,6 +58,12 @@ class OGLVideoOutput;
@property (assign) BOOL isHUDLagFrameCountVisible; @property (assign) BOOL isHUDLagFrameCountVisible;
@property (assign) BOOL isHUDCPULoadAverageVisible; @property (assign) BOOL isHUDCPULoadAverageVisible;
@property (assign) BOOL isHUDRealTimeClockVisible; @property (assign) BOOL isHUDRealTimeClockVisible;
@property (assign) NSColor *hudColorVideoFPS;
@property (assign) NSColor *hudColorRender3DFPS;
@property (assign) NSColor *hudColorFrameIndex;
@property (assign) NSColor *hudColorLagFrameCount;
@property (assign) NSColor *hudColorCPULoadAverage;
@property (assign) NSColor *hudColorRTC;
@property (assign) NSInteger displayMainVideoSource; @property (assign) NSInteger displayMainVideoSource;
@property (assign) NSInteger displayTouchVideoSource; @property (assign) NSInteger displayTouchVideoSource;
@property (assign) BOOL useVerticalSync; @property (assign) BOOL useVerticalSync;

View File

@ -573,6 +573,13 @@ static std::unordered_map<NSScreen *, DisplayWindowController *> _screenMap; //
[[self view] setIsHUDRealTimeClockVisible:[[NSUserDefaults standardUserDefaults] boolForKey:@"HUD_ShowRTC"]]; [[self view] setIsHUDRealTimeClockVisible:[[NSUserDefaults standardUserDefaults] boolForKey:@"HUD_ShowRTC"]];
// TODO: Show HUD Input. // TODO: Show HUD Input.
//[[self view] setIsHUDInputVisible:[[NSUserDefaults standardUserDefaults] boolForKey:@"HUD_ShowInput"]]; //[[self view] setIsHUDInputVisible:[[NSUserDefaults standardUserDefaults] boolForKey:@"HUD_ShowInput"]];
[[self view] setHudColorVideoFPS:[CocoaDSUtil NSColorFromRGBA8888:[[NSUserDefaults standardUserDefaults] integerForKey:@"HUD_Color_VideoFPS"]]];
[[self view] setHudColorRender3DFPS:[CocoaDSUtil NSColorFromRGBA8888:[[NSUserDefaults standardUserDefaults] integerForKey:@"HUD_Color_Render3DFPS"]]];
[[self view] setHudColorFrameIndex:[CocoaDSUtil NSColorFromRGBA8888:[[NSUserDefaults standardUserDefaults] integerForKey:@"HUD_Color_FrameIndex"]]];
[[self view] setHudColorLagFrameCount:[CocoaDSUtil NSColorFromRGBA8888:[[NSUserDefaults standardUserDefaults] integerForKey:@"HUD_Color_LagFrameCount"]]];
[[self view] setHudColorCPULoadAverage:[CocoaDSUtil NSColorFromRGBA8888:[[NSUserDefaults standardUserDefaults] integerForKey:@"HUD_Color_CPULoadAverage"]]];
[[self view] setHudColorRTC:[CocoaDSUtil NSColorFromRGBA8888:[[NSUserDefaults standardUserDefaults] integerForKey:@"HUD_Color_RTC"]]];
} }
- (BOOL) masterStatusBarState - (BOOL) masterStatusBarState
@ -1076,6 +1083,13 @@ static std::unordered_map<NSScreen *, DisplayWindowController *> _screenMap; //
// TODO: Show HUD Input. // TODO: Show HUD Input.
//[[NSUserDefaults standardUserDefaults] setBool:[[self view] isHUDInputVisible] forKey:@"HUD_ShowInput"]; //[[NSUserDefaults standardUserDefaults] setBool:[[self view] isHUDInputVisible] forKey:@"HUD_ShowInput"];
[[NSUserDefaults standardUserDefaults] setInteger:[CocoaDSUtil RGBA8888FromNSColor:[[self view] hudColorVideoFPS]] forKey:@"HUD_Color_VideoFPS"];
[[NSUserDefaults standardUserDefaults] setInteger:[CocoaDSUtil RGBA8888FromNSColor:[[self view] hudColorRender3DFPS]] forKey:@"HUD_Color_Render3DFPS"];
[[NSUserDefaults standardUserDefaults] setInteger:[CocoaDSUtil RGBA8888FromNSColor:[[self view] hudColorFrameIndex]] forKey:@"HUD_Color_FrameIndex"];
[[NSUserDefaults standardUserDefaults] setInteger:[CocoaDSUtil RGBA8888FromNSColor:[[self view] hudColorLagFrameCount]] forKey:@"HUD_Color_LagFrameCount"];
[[NSUserDefaults standardUserDefaults] setInteger:[CocoaDSUtil RGBA8888FromNSColor:[[self view] hudColorCPULoadAverage]] forKey:@"HUD_Color_CPULoadAverage"];
[[NSUserDefaults standardUserDefaults] setInteger:[CocoaDSUtil RGBA8888FromNSColor:[[self view] hudColorRTC]] forKey:@"HUD_Color_RTC"];
[[NSUserDefaults standardUserDefaults] synchronize]; [[NSUserDefaults standardUserDefaults] synchronize];
} }
@ -1668,6 +1682,12 @@ static std::unordered_map<NSScreen *, DisplayWindowController *> _screenMap; //
@dynamic isHUDLagFrameCountVisible; @dynamic isHUDLagFrameCountVisible;
@dynamic isHUDCPULoadAverageVisible; @dynamic isHUDCPULoadAverageVisible;
@dynamic isHUDRealTimeClockVisible; @dynamic isHUDRealTimeClockVisible;
@dynamic hudColorVideoFPS;
@dynamic hudColorRender3DFPS;
@dynamic hudColorFrameIndex;
@dynamic hudColorLagFrameCount;
@dynamic hudColorCPULoadAverage;
@dynamic hudColorRTC;
@dynamic displayMainVideoSource; @dynamic displayMainVideoSource;
@dynamic displayTouchVideoSource; @dynamic displayTouchVideoSource;
@dynamic useVerticalSync; @dynamic useVerticalSync;
@ -1801,6 +1821,66 @@ static std::unordered_map<NSScreen *, DisplayWindowController *> _screenMap; //
return [[self cdsVideoOutput] isHUDRealTimeClockVisible]; return [[self cdsVideoOutput] isHUDRealTimeClockVisible];
} }
- (void) setHudColorVideoFPS:(NSColor *)theColor
{
[[self cdsVideoOutput] setHudColorVideoFPS:[CocoaDSUtil RGBA8888FromNSColor:theColor]];
}
- (NSColor *) hudColorVideoFPS
{
return [CocoaDSUtil NSColorFromRGBA8888:[[self cdsVideoOutput] hudColorVideoFPS]];
}
- (void) setHudColorRender3DFPS:(NSColor *)theColor
{
[[self cdsVideoOutput] setHudColorRender3DFPS:[CocoaDSUtil RGBA8888FromNSColor:theColor]];
}
- (NSColor *) hudColorRender3DFPS
{
return [CocoaDSUtil NSColorFromRGBA8888:[[self cdsVideoOutput] hudColorRender3DFPS]];
}
- (void) setHudColorFrameIndex:(NSColor *)theColor
{
[[self cdsVideoOutput] setHudColorFrameIndex:[CocoaDSUtil RGBA8888FromNSColor:theColor]];
}
- (NSColor *) hudColorFrameIndex
{
return [CocoaDSUtil NSColorFromRGBA8888:[[self cdsVideoOutput] hudColorFrameIndex]];
}
- (void) setHudColorLagFrameCount:(NSColor *)theColor
{
[[self cdsVideoOutput] setHudColorLagFrameCount:[CocoaDSUtil RGBA8888FromNSColor:theColor]];
}
- (NSColor *) hudColorLagFrameCount
{
return [CocoaDSUtil NSColorFromRGBA8888:[[self cdsVideoOutput] hudColorLagFrameCount]];
}
- (void) setHudColorCPULoadAverage:(NSColor *)theColor
{
[[self cdsVideoOutput] setHudColorCPULoadAverage:[CocoaDSUtil RGBA8888FromNSColor:theColor]];
}
- (NSColor *) hudColorCPULoadAverage
{
return [CocoaDSUtil NSColorFromRGBA8888:[[self cdsVideoOutput] hudColorCPULoadAverage]];
}
- (void) setHudColorRTC:(NSColor *)theColor
{
[[self cdsVideoOutput] setHudColorRTC:[CocoaDSUtil RGBA8888FromNSColor:theColor]];
}
- (NSColor *) hudColorRTC
{
return [CocoaDSUtil NSColorFromRGBA8888:[[self cdsVideoOutput] hudColorRTC]];
}
- (void) setDisplayMainVideoSource:(NSInteger)displaySourceID - (void) setDisplayMainVideoSource:(NSInteger)displaySourceID
{ {
[[self cdsVideoOutput] setDisplayMainVideoSource:displaySourceID]; [[self cdsVideoOutput] setDisplayMainVideoSource:displaySourceID];

View File

@ -166,6 +166,7 @@ typedef DisplayViewShaderProperties DisplayViewShaderProperties;
id<MTLBuffer> _displayVtxPositionBuffer; id<MTLBuffer> _displayVtxPositionBuffer;
id<MTLBuffer> _displayTexCoordBuffer; id<MTLBuffer> _displayTexCoordBuffer;
id<MTLBuffer> _hudVtxPositionBuffer; id<MTLBuffer> _hudVtxPositionBuffer;
id<MTLBuffer> _hudVtxColorBuffer;
id<MTLBuffer> _hudTexCoordBuffer; id<MTLBuffer> _hudTexCoordBuffer;
id<MTLBuffer> bufCPUFilterSrcMain; id<MTLBuffer> bufCPUFilterSrcMain;
id<MTLBuffer> bufCPUFilterSrcTouch; id<MTLBuffer> bufCPUFilterSrcTouch;

View File

@ -766,6 +766,7 @@
_displayVtxPositionBuffer = nil; _displayVtxPositionBuffer = nil;
_displayTexCoordBuffer = nil; _displayTexCoordBuffer = nil;
_hudVtxPositionBuffer = nil; _hudVtxPositionBuffer = nil;
_hudVtxColorBuffer = nil;
_hudTexCoordBuffer = nil; _hudTexCoordBuffer = nil;
_texDisplaySrcDeposterize[NDSDisplayID_Main][0] = nil; _texDisplaySrcDeposterize[NDSDisplayID_Main][0] = nil;
@ -803,6 +804,7 @@
[_displayVtxPositionBuffer release]; [_displayVtxPositionBuffer release];
[_displayTexCoordBuffer release]; [_displayTexCoordBuffer release];
[_hudVtxPositionBuffer release]; [_hudVtxPositionBuffer release];
[_hudVtxColorBuffer release];
[_hudTexCoordBuffer release]; [_hudTexCoordBuffer release];
[_texDisplaySrcDeposterize[NDSDisplayID_Main][0] release]; [_texDisplaySrcDeposterize[NDSDisplayID_Main][0] release];
@ -1049,6 +1051,7 @@
_displayVtxPositionBuffer = [[[self device] newBufferWithLength:(sizeof(float) * (4 * 8)) options:MTLResourceStorageModeManaged] retain]; _displayVtxPositionBuffer = [[[self device] newBufferWithLength:(sizeof(float) * (4 * 8)) options:MTLResourceStorageModeManaged] retain];
_displayTexCoordBuffer = [[[self device] newBufferWithLength:(sizeof(float) * (4 * 8)) options:MTLResourceStorageModeManaged] retain]; _displayTexCoordBuffer = [[[self device] newBufferWithLength:(sizeof(float) * (4 * 8)) options:MTLResourceStorageModeManaged] retain];
_hudVtxPositionBuffer = [[[self device] newBufferWithLength:HUD_VERTEX_ATTRIBUTE_BUFFER_SIZE options:MTLResourceStorageModeManaged] retain]; _hudVtxPositionBuffer = [[[self device] newBufferWithLength:HUD_VERTEX_ATTRIBUTE_BUFFER_SIZE options:MTLResourceStorageModeManaged] retain];
_hudVtxColorBuffer = [[[self device] newBufferWithLength:HUD_VERTEX_COLOR_ATTRIBUTE_BUFFER_SIZE options:MTLResourceStorageModeManaged] retain];
_hudTexCoordBuffer = [[[self device] newBufferWithLength:HUD_VERTEX_ATTRIBUTE_BUFFER_SIZE options:MTLResourceStorageModeManaged] retain]; _hudTexCoordBuffer = [[[self device] newBufferWithLength:HUD_VERTEX_ATTRIBUTE_BUFFER_SIZE options:MTLResourceStorageModeManaged] retain];
DisplayViewShaderProperties *viewProps = (DisplayViewShaderProperties *)[_cdvPropertiesBuffer contents]; DisplayViewShaderProperties *viewProps = (DisplayViewShaderProperties *)[_cdvPropertiesBuffer contents];
@ -1188,7 +1191,7 @@
{ {
for (size_t pixIndex = 0; pixIndex < tileSize; pixIndex++) for (size_t pixIndex = 0; pixIndex < tileSize; pixIndex++)
{ {
const uint32_t colorRGBA8888 = 0x50000000; const uint32_t colorRGBA8888 = 0xFFFFFFFF;
charMapBuffer[(tileSize + pixIndex) + (rowIndex * (16 * tileSize))] = colorRGBA8888; charMapBuffer[(tileSize + pixIndex) + (rowIndex * (16 * tileSize))] = colorRGBA8888;
} }
} }
@ -1588,9 +1591,12 @@
{ {
if (_cdv->HUDNeedsUpdate()) if (_cdv->HUDNeedsUpdate())
{ {
_cdv->SetHUDVertices((float)_cdv->GetViewProperties().clientWidth, (float)_cdv->GetViewProperties().clientHeight, (float *)[_hudVtxPositionBuffer contents]); _cdv->SetHUDPositionVertices((float)_cdv->GetViewProperties().clientWidth, (float)_cdv->GetViewProperties().clientHeight, (float *)[_hudVtxPositionBuffer contents]);
[_hudVtxPositionBuffer didModifyRange:NSMakeRange(0, sizeof(float) * hudLength * 8)]; [_hudVtxPositionBuffer didModifyRange:NSMakeRange(0, sizeof(float) * hudLength * 8)];
_cdv->SetHUDColorVertices((uint32_t *)[_hudVtxColorBuffer contents]);
[_hudVtxColorBuffer didModifyRange:NSMakeRange(0, sizeof(uint32_t) * hudLength * 4)];
_cdv->SetHUDTextureCoordinates((float *)[_hudTexCoordBuffer contents]); _cdv->SetHUDTextureCoordinates((float *)[_hudTexCoordBuffer contents]);
[_hudTexCoordBuffer didModifyRange:NSMakeRange(0, sizeof(float) * hudLength * 8)]; [_hudTexCoordBuffer didModifyRange:NSMakeRange(0, sizeof(float) * hudLength * 8)];
@ -1599,8 +1605,9 @@
[ce setRenderPipelineState:[sharedData hudPipeline]]; [ce setRenderPipelineState:[sharedData hudPipeline]];
[ce setVertexBuffer:_hudVtxPositionBuffer offset:0 atIndex:0]; [ce setVertexBuffer:_hudVtxPositionBuffer offset:0 atIndex:0];
[ce setVertexBuffer:_hudTexCoordBuffer offset:0 atIndex:1]; [ce setVertexBuffer:_hudVtxColorBuffer offset:0 atIndex:1];
[ce setVertexBuffer:_cdvPropertiesBuffer offset:0 atIndex:2]; [ce setVertexBuffer:_hudTexCoordBuffer offset:0 atIndex:2];
[ce setVertexBuffer:_cdvPropertiesBuffer offset:0 atIndex:3];
[ce setFragmentTexture:[self texHUDCharMap] atIndex:0]; [ce setFragmentTexture:[self texHUDCharMap] atIndex:0];
// First, draw the backing text box. // First, draw the backing text box.

View File

@ -23,6 +23,7 @@ using namespace metal;
struct HUDVtx struct HUDVtx
{ {
float4 position [[position]]; float4 position [[position]];
float4 color;
float2 texCoord; float2 texCoord;
bool isBox; bool isBox;
bool lowerHUDMipMapLevel; bool lowerHUDMipMapLevel;
@ -143,15 +144,17 @@ float dist_EPXPlus(const float3 pixA, const float3 pixB)
#pragma mark HUD Shader Functions #pragma mark HUD Shader Functions
vertex HUDVtx hud_vertex(const device float2 *inPosition [[buffer(0)]], vertex HUDVtx hud_vertex(const device float2 *inPosition [[buffer(0)]],
const device float2 *inTexCoord [[buffer(1)]], const device uint32_t *inColor [[buffer(1)]],
const constant DisplayViewShaderProperties &viewProps [[buffer(2)]], const device float2 *inTexCoord [[buffer(2)]],
const constant DisplayViewShaderProperties &viewProps [[buffer(3)]],
const uint vid [[vertex_id]]) const uint vid [[vertex_id]])
{ {
const float2x2 projection = float2x2( float2(2.0/viewProps.width, 0.0), const float2x2 projection = float2x2( float2(2.0f/viewProps.width, 0.0f),
float2( 0.0, 2.0/viewProps.height)); float2( 0.0f, 2.0f/viewProps.height));
HUDVtx outVtx; HUDVtx outVtx;
outVtx.position = float4(projection * inPosition[vid], 0.0, 1.0); outVtx.position = float4(projection * inPosition[vid], 0.0f, 1.0f);
outVtx.color = float4( (float)((inColor[vid] >> 0) & 0xFF) / 255.0f, (float)((inColor[vid] >> 8) & 0xFF) / 255.0f, (float)((inColor[vid] >> 16) & 0xFF) / 255.0f, (float)((inColor[vid] >> 24) & 0xFF) / 255.0f );
outVtx.texCoord = inTexCoord[vid]; outVtx.texCoord = inTexCoord[vid];
outVtx.isBox = (vid < 4); outVtx.isBox = (vid < 4);
outVtx.lowerHUDMipMapLevel = (viewProps.lowerHUDMipMapLevel == 1); outVtx.lowerHUDMipMapLevel = (viewProps.lowerHUDMipMapLevel == 1);
@ -163,7 +166,7 @@ fragment float4 hud_fragment(const HUDVtx vtx [[stage_in]],
const texture2d<float> tex [[texture(0)]], const texture2d<float> tex [[texture(0)]],
const sampler samp [[sampler(0)]]) const sampler samp [[sampler(0)]])
{ {
return tex.sample(samp, vtx.texCoord, (vtx.lowerHUDMipMapLevel) ? level(-0.50f) : level(0.00f)); return tex.sample(samp, vtx.texCoord, (vtx.lowerHUDMipMapLevel) ? level(-0.50f) : level(0.00f)) * vtx.color;
} }
#pragma mark Output Filters #pragma mark Output Filters
@ -173,19 +176,19 @@ vertex DisplayVtx display_output_vertex(const device float2 *inPosition [[buffer
const constant DisplayViewShaderProperties &viewProps [[buffer(2)]], const constant DisplayViewShaderProperties &viewProps [[buffer(2)]],
const uint vid [[vertex_id]]) const uint vid [[vertex_id]])
{ {
const float angleRadians = viewProps.rotation * (M_PI_F/180.0); const float angleRadians = viewProps.rotation * (M_PI_F/180.0f);
const float2x2 projection = float2x2( float2(2.0/viewProps.width, 0.0), const float2x2 projection = float2x2( float2(2.0f/viewProps.width, 0.0f),
float2( 0.0, 2.0/viewProps.height)); float2( 0.0f, 2.0f/viewProps.height));
const float2x2 rotation = float2x2( float2( cos(angleRadians), sin(angleRadians)), const float2x2 rotation = float2x2( float2( cos(angleRadians), sin(angleRadians)),
float2(-sin(angleRadians), cos(angleRadians))); float2(-sin(angleRadians), cos(angleRadians)));
const float2x2 scale = float2x2( float2(viewProps.viewScale, 0.0), const float2x2 scale = float2x2( float2(viewProps.viewScale, 0.0f),
float2( 0.0, viewProps.viewScale)); float2( 0.0f, viewProps.viewScale));
DisplayVtx outVtx; DisplayVtx outVtx;
outVtx.position = float4(projection * rotation * scale * inPosition[vid], 0.0, 1.0); outVtx.position = float4(projection * rotation * scale * inPosition[vid], 0.0f, 1.0f);
outVtx.texCoord = inTexCoord[vid]; outVtx.texCoord = inTexCoord[vid];
return outVtx; return outVtx;
@ -196,19 +199,19 @@ vertex DisplayVtx display_output_bicubic_vertex(const device float2 *inPosition
const constant DisplayViewShaderProperties &viewProps [[buffer(2)]], const constant DisplayViewShaderProperties &viewProps [[buffer(2)]],
const uint vid [[vertex_id]]) const uint vid [[vertex_id]])
{ {
const float angleRadians = viewProps.rotation * (M_PI_F/180.0); const float angleRadians = viewProps.rotation * (M_PI_F/180.0f);
const float2x2 projection = float2x2( float2(2.0/viewProps.width, 0.0), const float2x2 projection = float2x2( float2(2.0f/viewProps.width, 0.0f),
float2( 0.0, 2.0/viewProps.height)); float2( 0.0f, 2.0f/viewProps.height));
const float2x2 rotation = float2x2( float2( cos(angleRadians), sin(angleRadians)), const float2x2 rotation = float2x2( float2( cos(angleRadians), sin(angleRadians)),
float2(-sin(angleRadians), cos(angleRadians))); float2(-sin(angleRadians), cos(angleRadians)));
const float2x2 scale = float2x2( float2(viewProps.viewScale, 0.0), const float2x2 scale = float2x2( float2(viewProps.viewScale, 0.0f),
float2( 0.0, viewProps.viewScale)); float2( 0.0f, viewProps.viewScale));
DisplayVtx outVtx; DisplayVtx outVtx;
outVtx.position = float4(projection * rotation * scale * inPosition[vid], 0.0, 1.0); outVtx.position = float4(projection * rotation * scale * inPosition[vid], 0.0f, 1.0f);
outVtx.texCoord = floor(inTexCoord[vid] - 0.5f) + 0.5f; outVtx.texCoord = floor(inTexCoord[vid] - 0.5f) + 0.5f;
return outVtx; return outVtx;
@ -2666,8 +2669,6 @@ kernel void pixel_scaler_6xBRZ(const uint2 inPosition [[thread_position_in_grid]
src[0] src[0]
}; };
//float3 dst[36] = {src[0]};
// Scale pixel // Scale pixel
if (IsBlendingNeeded(blendResult)) if (IsBlendingNeeded(blendResult))
{ {

View File

@ -85,6 +85,9 @@
isDeveloperPlusBuild = NO; isDeveloperPlusBuild = NO;
#endif #endif
RGBA8888ToNSColorValueTransformer *nsColorTransformer = [[[RGBA8888ToNSColorValueTransformer alloc] init] autorelease];
[NSValueTransformer setValueTransformer:nsColorTransformer forName:@"RGBA8888ToNSColorValueTransformer"];
return self; return self;
} }
@ -607,6 +610,13 @@
// TODO: Show HUD Input. // TODO: Show HUD Input.
//const BOOL hudShowInput = [(NSNumber *)[windowProperties valueForKey:@"hudShowInput"] boolValue]; //const BOOL hudShowInput = [(NSNumber *)[windowProperties valueForKey:@"hudShowInput"] boolValue];
const NSUInteger hudColorVideoFPS = ([windowProperties objectForKey:@"hudColorVideoFPS"] != nil) ? [(NSNumber *)[windowProperties valueForKey:@"hudColorVideoFPS"] unsignedIntegerValue] : [[NSUserDefaults standardUserDefaults] integerForKey:@"HUD_Color_VideoFPS"];
const NSUInteger hudColorRender3DFPS = ([windowProperties objectForKey:@"hudColorRender3DFPS"] != nil) ? [(NSNumber *)[windowProperties valueForKey:@"hudColorRender3DFPS"] unsignedIntegerValue] : [[NSUserDefaults standardUserDefaults] integerForKey:@"HUD_Color_Render3DFPS"];
const NSUInteger hudColorFrameIndex = ([windowProperties objectForKey:@"hudColorFrameIndex"] != nil) ? [(NSNumber *)[windowProperties valueForKey:@"hudColorFrameIndex"] unsignedIntegerValue] : [[NSUserDefaults standardUserDefaults] integerForKey:@"HUD_Color_FrameIndex"];
const NSUInteger hudColorLagFrameCount = ([windowProperties objectForKey:@"hudColorLagFrameCount"] != nil) ? [(NSNumber *)[windowProperties valueForKey:@"hudColorLagFrameCount"] unsignedIntegerValue] : [[NSUserDefaults standardUserDefaults] integerForKey:@"HUD_Color_LagFrameCount"];
const NSUInteger hudColorCPULoadAverage = ([windowProperties objectForKey:@"hudColorCPULoadAverage"] != nil) ? [(NSNumber *)[windowProperties valueForKey:@"hudColorCPULoadAverage"] unsignedIntegerValue] : [[NSUserDefaults standardUserDefaults] integerForKey:@"HUD_Color_CPULoadAverage"];
const NSUInteger hudColorRTC = ([windowProperties objectForKey:@"hudColorRTC"] != nil) ? [(NSNumber *)[windowProperties valueForKey:@"hudColorRTC"] unsignedIntegerValue] : [[NSUserDefaults standardUserDefaults] integerForKey:@"HUD_Color_RTC"];
const NSInteger screenshotFileFormat = ([windowProperties objectForKey:@"screenshotFileFormat"] != nil) ? [(NSNumber *)[windowProperties valueForKey:@"screenshotFileFormat"] integerValue] : NSTIFFFileType; const NSInteger screenshotFileFormat = ([windowProperties objectForKey:@"screenshotFileFormat"] != nil) ? [(NSNumber *)[windowProperties valueForKey:@"screenshotFileFormat"] integerValue] : NSTIFFFileType;
const BOOL useVerticalSync = ([windowProperties objectForKey:@"useVerticalSync"] != nil) ? [(NSNumber *)[windowProperties valueForKey:@"useVerticalSync"] boolValue] : YES; const BOOL useVerticalSync = ([windowProperties objectForKey:@"useVerticalSync"] != nil) ? [(NSNumber *)[windowProperties valueForKey:@"useVerticalSync"] boolValue] : YES;
const BOOL isMinSizeNormal = ([windowProperties objectForKey:@"isMinSizeNormal"] != nil) ? [(NSNumber *)[windowProperties valueForKey:@"isMinSizeNormal"] boolValue] : YES; const BOOL isMinSizeNormal = ([windowProperties objectForKey:@"isMinSizeNormal"] != nil) ? [(NSNumber *)[windowProperties valueForKey:@"isMinSizeNormal"] boolValue] : YES;
@ -652,6 +662,13 @@
[[windowController view] setIsHUDCPULoadAverageVisible:hudShowCPULoadAverage]; [[windowController view] setIsHUDCPULoadAverageVisible:hudShowCPULoadAverage];
[[windowController view] setIsHUDRealTimeClockVisible:hudShowRTC]; [[windowController view] setIsHUDRealTimeClockVisible:hudShowRTC];
[[windowController view] setHudColorVideoFPS:[CocoaDSUtil NSColorFromRGBA8888:(uint32_t)hudColorVideoFPS]];
[[windowController view] setHudColorRender3DFPS:[CocoaDSUtil NSColorFromRGBA8888:(uint32_t)hudColorRender3DFPS]];
[[windowController view] setHudColorFrameIndex:[CocoaDSUtil NSColorFromRGBA8888:(uint32_t)hudColorFrameIndex]];
[[windowController view] setHudColorLagFrameCount:[CocoaDSUtil NSColorFromRGBA8888:(uint32_t)hudColorLagFrameCount]];
[[windowController view] setHudColorCPULoadAverage:[CocoaDSUtil NSColorFromRGBA8888:(uint32_t)hudColorCPULoadAverage]];
[[windowController view] setHudColorRTC:[CocoaDSUtil NSColorFromRGBA8888:(uint32_t)hudColorRTC]];
[[windowController masterWindow] setFrameOrigin:NSMakePoint(frameX, frameY)]; [[windowController masterWindow] setFrameOrigin:NSMakePoint(frameX, frameY)];
// If this is the last window in the list, make this window key and main. // If this is the last window in the list, make this window key and main.
@ -723,6 +740,12 @@
[NSNumber numberWithBool:[[windowController view] isHUDLagFrameCountVisible]], @"hudShowLagFrameCount", [NSNumber numberWithBool:[[windowController view] isHUDLagFrameCountVisible]], @"hudShowLagFrameCount",
[NSNumber numberWithBool:[[windowController view] isHUDCPULoadAverageVisible]], @"hudShowCPULoadAverage", [NSNumber numberWithBool:[[windowController view] isHUDCPULoadAverageVisible]], @"hudShowCPULoadAverage",
[NSNumber numberWithBool:[[windowController view] isHUDRealTimeClockVisible]], @"hudShowRTC", [NSNumber numberWithBool:[[windowController view] isHUDRealTimeClockVisible]], @"hudShowRTC",
[NSNumber numberWithUnsignedInteger:[CocoaDSUtil RGBA8888FromNSColor:[[windowController view] hudColorVideoFPS]]], @"hudColorVideoFPS",
[NSNumber numberWithUnsignedInteger:[CocoaDSUtil RGBA8888FromNSColor:[[windowController view] hudColorRender3DFPS]]], @"hudColorRender3DFPS",
[NSNumber numberWithUnsignedInteger:[CocoaDSUtil RGBA8888FromNSColor:[[windowController view] hudColorFrameIndex]]], @"hudColorFrameIndex",
[NSNumber numberWithUnsignedInteger:[CocoaDSUtil RGBA8888FromNSColor:[[windowController view] hudColorLagFrameCount]]], @"hudColorLagFrameCount",
[NSNumber numberWithUnsignedInteger:[CocoaDSUtil RGBA8888FromNSColor:[[windowController view] hudColorCPULoadAverage]]], @"hudColorCPULoadAverage",
[NSNumber numberWithUnsignedInteger:[CocoaDSUtil RGBA8888FromNSColor:[[windowController view] hudColorRTC]]], @"hudColorRTC",
[NSNumber numberWithBool:[windowController isMinSizeNormal]], @"isMinSizeNormal", [NSNumber numberWithBool:[windowController isMinSizeNormal]], @"isMinSizeNormal",
[NSNumber numberWithBool:[windowController masterStatusBarState]], @"isShowingStatusBar", [NSNumber numberWithBool:[windowController masterStatusBarState]], @"isShowingStatusBar",
[NSNumber numberWithBool:[windowController isFullScreen]], @"isInFullScreenMode", [NSNumber numberWithBool:[windowController isFullScreen]], @"isInFullScreenMode",