[Glide64] Use enum for TextureFilter/
This commit is contained in:
parent
ea35a02614
commit
d2918162e7
|
@ -105,17 +105,6 @@ void ConfigCleanup(void)
|
||||||
|
|
||||||
void CloseConfig();
|
void CloseConfig();
|
||||||
|
|
||||||
uint32_t texfltr[] =
|
|
||||||
{
|
|
||||||
NO_FILTER, //"None"
|
|
||||||
SMOOTH_FILTER_1, //"Smooth filtering 1"
|
|
||||||
SMOOTH_FILTER_2, //"Smooth filtering 2"
|
|
||||||
SMOOTH_FILTER_3, //"Smooth filtering 3"
|
|
||||||
SMOOTH_FILTER_4, //"Smooth filtering 4"
|
|
||||||
SHARP_FILTER_1, //"Sharp filtering 1"
|
|
||||||
SHARP_FILTER_2, //"Sharp filtering 2"
|
|
||||||
};
|
|
||||||
|
|
||||||
uint32_t texenht[] =
|
uint32_t texenht[] =
|
||||||
{
|
{
|
||||||
NO_ENHANCEMENT, //"None"
|
NO_ENHANCEMENT, //"None"
|
||||||
|
@ -644,14 +633,14 @@ public:
|
||||||
TTSetTxt(IDC_TXT_ENH_FILTER, tooltip.c_str());
|
TTSetTxt(IDC_TXT_ENH_FILTER, tooltip.c_str());
|
||||||
TTSetTxt(IDC_CMB_ENH_FILTER, tooltip.c_str());
|
TTSetTxt(IDC_CMB_ENH_FILTER, tooltip.c_str());
|
||||||
m_cmbEnhFilter.Attach(GetDlgItem(IDC_CMB_ENH_FILTER));
|
m_cmbEnhFilter.Attach(GetDlgItem(IDC_CMB_ENH_FILTER));
|
||||||
m_cmbEnhFilter.SetItemData(m_cmbEnhFilter.AddString("None"), 0);
|
m_cmbEnhFilter.SetItemData(m_cmbEnhFilter.AddString("None"), CSettings::TextureFilter_None);
|
||||||
m_cmbEnhFilter.SetItemData(m_cmbEnhFilter.AddString("Smooth filtering 1"), 1);
|
m_cmbEnhFilter.SetItemData(m_cmbEnhFilter.AddString("Smooth filtering 1"), CSettings::TextureFilter_SmoothFiltering);
|
||||||
m_cmbEnhFilter.SetItemData(m_cmbEnhFilter.AddString("Smooth filtering 2"), 2);
|
m_cmbEnhFilter.SetItemData(m_cmbEnhFilter.AddString("Smooth filtering 2"), CSettings::TextureFilter_SmoothFiltering2);
|
||||||
m_cmbEnhFilter.SetItemData(m_cmbEnhFilter.AddString("Smooth filtering 3"), 3);
|
m_cmbEnhFilter.SetItemData(m_cmbEnhFilter.AddString("Smooth filtering 3"), CSettings::TextureFilter_SmoothFiltering3);
|
||||||
m_cmbEnhFilter.SetItemData(m_cmbEnhFilter.AddString("Smooth filtering 4"), 4);
|
m_cmbEnhFilter.SetItemData(m_cmbEnhFilter.AddString("Smooth filtering 4"), CSettings::TextureFilter_SmoothFiltering4);
|
||||||
m_cmbEnhFilter.SetItemData(m_cmbEnhFilter.AddString("Sharp filtering 1"), 5);
|
m_cmbEnhFilter.SetItemData(m_cmbEnhFilter.AddString("Sharp filtering 1"), CSettings::TextureFilter_SharpFiltering1);
|
||||||
m_cmbEnhFilter.SetItemData(m_cmbEnhFilter.AddString("Sharp filtering 2"), 6);
|
m_cmbEnhFilter.SetItemData(m_cmbEnhFilter.AddString("Sharp filtering 2"), CSettings::TextureFilter_SharpFiltering2);
|
||||||
SetComboBoxIndex(m_cmbEnhFilter, g_settings->ghq_fltr);
|
SetComboBoxIndex(m_cmbEnhFilter, g_settings->ghq_fltr());
|
||||||
|
|
||||||
tooltip = "Texture enhancement:\n\n7 different filters are selectable here, each one with a distinctive look.\nBe aware of possible performance impacts.\n\nIMPORTANT: 'Store' mode - saves textures in cache 'as is'.\nIt can improve performance in games, which load many textures.\nDisable 'Ignore backgrounds' option for better result.\n\n[Recommended: your preference]";
|
tooltip = "Texture enhancement:\n\n7 different filters are selectable here, each one with a distinctive look.\nBe aware of possible performance impacts.\n\nIMPORTANT: 'Store' mode - saves textures in cache 'as is'.\nIt can improve performance in games, which load many textures.\nDisable 'Ignore backgrounds' option for better result.\n\n[Recommended: your preference]";
|
||||||
TTSetTxt(IDC_TXT_ENHANCEMENT, tooltip.c_str());
|
TTSetTxt(IDC_TXT_ENHANCEMENT, tooltip.c_str());
|
||||||
|
@ -747,7 +736,7 @@ public:
|
||||||
m_textTexCache.GetWindowText(texcache, sizeof(texcache));
|
m_textTexCache.GetWindowText(texcache, sizeof(texcache));
|
||||||
|
|
||||||
CSettings oldsettings = *g_settings;
|
CSettings oldsettings = *g_settings;
|
||||||
g_settings->ghq_fltr = m_cmbEnhFilter.GetItemData(m_cmbEnhFilter.GetCurSel());
|
g_settings->SetGhqFltr((CSettings::TextureFilter_t)m_cmbEnhFilter.GetItemData(m_cmbEnhFilter.GetCurSel()));
|
||||||
g_settings->ghq_enht = m_cmbEnhEnhancement.GetItemData(m_cmbEnhEnhancement.GetCurSel());
|
g_settings->ghq_enht = m_cmbEnhEnhancement.GetItemData(m_cmbEnhEnhancement.GetCurSel());
|
||||||
g_settings->ghq_cache_size = atoi(texcache);
|
g_settings->ghq_cache_size = atoi(texcache);
|
||||||
g_settings->ghq_enht_nobg = (int)m_cbxEnhIgnoreBG.GetCheck() == BST_CHECKED;
|
g_settings->ghq_enht_nobg = (int)m_cbxEnhIgnoreBG.GetCheck() == BST_CHECKED;
|
||||||
|
|
|
@ -807,11 +807,11 @@ int InitGfx()
|
||||||
|
|
||||||
if (!g_settings->ghq_use)
|
if (!g_settings->ghq_use)
|
||||||
{
|
{
|
||||||
g_settings->ghq_use = g_settings->ghq_fltr || g_settings->ghq_enht /*|| g_settings->ghq_cmpr*/ || g_settings->ghq_hirs;
|
g_settings->ghq_use = g_settings->ghq_fltr() != CSettings::TextureFilter_None || g_settings->ghq_enht /*|| g_settings->ghq_cmpr*/ || g_settings->ghq_hirs;
|
||||||
if (g_settings->ghq_use)
|
if (g_settings->ghq_use)
|
||||||
{
|
{
|
||||||
/* Plugin path */
|
/* Plugin path */
|
||||||
int options = texfltr[g_settings->ghq_fltr] | texenht[g_settings->ghq_enht] | texcmpr[g_settings->ghq_cmpr] | texhirs[g_settings->ghq_hirs];
|
int options = g_settings->ghq_fltr() | texenht[g_settings->ghq_enht] | texcmpr[g_settings->ghq_cmpr] | texhirs[g_settings->ghq_hirs];
|
||||||
if (g_settings->ghq_enht_cmpr)
|
if (g_settings->ghq_enht_cmpr)
|
||||||
options |= COMPRESS_TEX;
|
options |= COMPRESS_TEX;
|
||||||
if (g_settings->ghq_hirs_cmpr)
|
if (g_settings->ghq_hirs_cmpr)
|
||||||
|
|
|
@ -31,7 +31,7 @@ buff_clear(0),
|
||||||
m_frame_buffer(0),
|
m_frame_buffer(0),
|
||||||
//Texture filtering options
|
//Texture filtering options
|
||||||
texture_dir(""),
|
texture_dir(""),
|
||||||
ghq_fltr(0),
|
m_ghq_fltr(TextureFilter_None),
|
||||||
ghq_enht(0),
|
ghq_enht(0),
|
||||||
ghq_cmpr(0),
|
ghq_cmpr(0),
|
||||||
ghq_hirs(0),
|
ghq_hirs(0),
|
||||||
|
@ -128,7 +128,7 @@ void CSettings::RegisterSettings(void)
|
||||||
general_setting(Set_wfmode, "wfmode", 1);
|
general_setting(Set_wfmode, "wfmode", 1);
|
||||||
general_setting(Set_unk_as_red, "unk_as_red", 0);
|
general_setting(Set_unk_as_red, "unk_as_red", 0);
|
||||||
general_setting(Set_unk_clear, "unk_clear", 0);
|
general_setting(Set_unk_clear, "unk_clear", 0);
|
||||||
general_setting(Set_ghq_fltr, "ghq_fltr", 0);
|
general_setting(Set_ghq_fltr, "ghq_fltr", TextureFilter_None);
|
||||||
general_setting(Set_ghq_cmpr, "ghq_cmpr", 0);
|
general_setting(Set_ghq_cmpr, "ghq_cmpr", 0);
|
||||||
general_setting(Set_ghq_enht, "ghq_enht", 0);
|
general_setting(Set_ghq_enht, "ghq_enht", 0);
|
||||||
general_setting(Set_ghq_hirs, "ghq_hirs", 0);
|
general_setting(Set_ghq_hirs, "ghq_hirs", 0);
|
||||||
|
@ -242,6 +242,15 @@ void CSettings::SetSwapMode(SwapMode_t value)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CSettings::SetGhqFltr(TextureFilter_t value)
|
||||||
|
{
|
||||||
|
if (value != m_ghq_fltr)
|
||||||
|
{
|
||||||
|
m_ghq_fltr = value;
|
||||||
|
m_dirty = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void CSettings::UpdateFrameBufferBits(uint32_t BitsToAdd, uint32_t BitsToRemove)
|
void CSettings::UpdateFrameBufferBits(uint32_t BitsToAdd, uint32_t BitsToRemove)
|
||||||
{
|
{
|
||||||
uint32_t frame_buffer_original = m_frame_buffer;
|
uint32_t frame_buffer_original = m_frame_buffer;
|
||||||
|
@ -325,7 +334,7 @@ void CSettings::ReadSettings()
|
||||||
memset(texture_dir, 0, sizeof(texture_dir));
|
memset(texture_dir, 0, sizeof(texture_dir));
|
||||||
GetSystemSettingSz(Set_texture_dir, texture_dir, sizeof(texture_dir));
|
GetSystemSettingSz(Set_texture_dir, texture_dir, sizeof(texture_dir));
|
||||||
this->texture_dir = texture_dir;
|
this->texture_dir = texture_dir;
|
||||||
this->ghq_fltr = (uint8_t)GetSetting(Set_ghq_fltr);
|
m_ghq_fltr = (TextureFilter_t)GetSetting(Set_ghq_fltr);
|
||||||
this->ghq_cmpr = (uint8_t)GetSetting(Set_ghq_cmpr);
|
this->ghq_cmpr = (uint8_t)GetSetting(Set_ghq_cmpr);
|
||||||
this->ghq_enht = (uint8_t)GetSetting(Set_ghq_enht);
|
this->ghq_enht = (uint8_t)GetSetting(Set_ghq_enht);
|
||||||
this->ghq_hirs = (uint8_t)GetSetting(Set_ghq_hirs);
|
this->ghq_hirs = (uint8_t)GetSetting(Set_ghq_hirs);
|
||||||
|
@ -597,7 +606,7 @@ void CSettings::WriteSettings(void)
|
||||||
SetSetting(Set_unk_clear, g_settings->unk_clear);
|
SetSetting(Set_unk_clear, g_settings->unk_clear);
|
||||||
#endif //_ENDUSER_RELEASE_
|
#endif //_ENDUSER_RELEASE_
|
||||||
|
|
||||||
SetSetting(Set_ghq_fltr, g_settings->ghq_fltr);
|
SetSetting(Set_ghq_fltr, m_ghq_fltr);
|
||||||
SetSetting(Set_ghq_cmpr, g_settings->ghq_cmpr);
|
SetSetting(Set_ghq_cmpr, g_settings->ghq_cmpr);
|
||||||
SetSetting(Set_ghq_enht, g_settings->ghq_enht);
|
SetSetting(Set_ghq_enht, g_settings->ghq_enht);
|
||||||
SetSetting(Set_ghq_hirs, g_settings->ghq_hirs);
|
SetSetting(Set_ghq_hirs, g_settings->ghq_hirs);
|
||||||
|
|
|
@ -82,7 +82,18 @@ public:
|
||||||
Filter_ForceBilinear = 1,
|
Filter_ForceBilinear = 1,
|
||||||
Filter_ForcePointSampled = 2,
|
Filter_ForcePointSampled = 2,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum TextureFilter_t
|
||||||
|
{
|
||||||
|
TextureFilter_None = 0x00,
|
||||||
|
TextureFilter_SmoothFiltering = 0x01,
|
||||||
|
TextureFilter_SmoothFiltering2 = 0x02,
|
||||||
|
TextureFilter_SmoothFiltering3 = 0x03,
|
||||||
|
TextureFilter_SmoothFiltering4 = 0x04,
|
||||||
|
TextureFilter_SharpFiltering1 = 0x10,
|
||||||
|
TextureFilter_SharpFiltering2 = 0x20,
|
||||||
|
};
|
||||||
|
|
||||||
enum SwapMode_t
|
enum SwapMode_t
|
||||||
{
|
{
|
||||||
SwapMode_Old = 0,
|
SwapMode_Old = 0,
|
||||||
|
@ -155,7 +166,7 @@ public:
|
||||||
|
|
||||||
//Texture filtering options
|
//Texture filtering options
|
||||||
std::string texture_dir;
|
std::string texture_dir;
|
||||||
int ghq_fltr;
|
inline TextureFilter_t ghq_fltr(void) const { return m_ghq_fltr; }
|
||||||
int ghq_enht;
|
int ghq_enht;
|
||||||
int ghq_cmpr;
|
int ghq_cmpr;
|
||||||
int ghq_hirs;
|
int ghq_hirs;
|
||||||
|
@ -220,6 +231,7 @@ public:
|
||||||
void SetLODmode(PixelLevelOfDetail_t value);
|
void SetLODmode(PixelLevelOfDetail_t value);
|
||||||
void SetFiltering(Filtering_t value);
|
void SetFiltering(Filtering_t value);
|
||||||
void SetSwapMode(SwapMode_t value);
|
void SetSwapMode(SwapMode_t value);
|
||||||
|
void SetGhqFltr(TextureFilter_t value);
|
||||||
void UpdateFrameBufferBits(uint32_t BitsToAdd, uint32_t BitsToRemove);
|
void UpdateFrameBufferBits(uint32_t BitsToAdd, uint32_t BitsToRemove);
|
||||||
|
|
||||||
void ReadGameSettings(const char * name);
|
void ReadGameSettings(const char * name);
|
||||||
|
@ -240,6 +252,7 @@ private:
|
||||||
Filtering_t m_filtering;
|
Filtering_t m_filtering;
|
||||||
SwapMode_t m_swapmode;
|
SwapMode_t m_swapmode;
|
||||||
PixelLevelOfDetail_t m_lodmode;
|
PixelLevelOfDetail_t m_lodmode;
|
||||||
|
TextureFilter_t m_ghq_fltr;
|
||||||
StippleMode_t m_stipple_mode;
|
StippleMode_t m_stipple_mode;
|
||||||
hacks_t m_hacks;
|
hacks_t m_hacks;
|
||||||
};
|
};
|
||||||
|
|
|
@ -163,8 +163,7 @@ typedef struct {
|
||||||
uint32_t lr_x;
|
uint32_t lr_x;
|
||||||
uint32_t lr_y;
|
uint32_t lr_y;
|
||||||
} SCISSOR;
|
} SCISSOR;
|
||||||
|
|
||||||
extern uint32_t texfltr[];
|
|
||||||
extern uint32_t texenht[];
|
extern uint32_t texenht[];
|
||||||
extern uint32_t texcmpr[];
|
extern uint32_t texcmpr[];
|
||||||
extern uint32_t texhirs[];
|
extern uint32_t texhirs[];
|
||||||
|
|
Loading…
Reference in New Issue