Cocoa Port: NEW FEATURE - Users can now apply custom colors to individual HUD line items.
This commit is contained in:
parent
2b9bc2509a
commit
4cfa910e75
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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
|
||||||
{
|
{
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
Binary file not shown.
File diff suppressed because it is too large
Load Diff
|
@ -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;
|
||||||
|
|
|
@ -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];
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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.
|
||||||
|
|
|
@ -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))
|
||||||
{
|
{
|
||||||
|
|
|
@ -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",
|
||||||
|
|
Loading…
Reference in New Issue