Adjust text AA to be more gamma-correct. Switch everything to Open Sans.

This commit is contained in:
elasota
2020-01-19 07:36:44 -05:00
parent 93b4554961
commit 1b5720c118
17 changed files with 428 additions and 157 deletions

View File

@@ -1,9 +1,10 @@
#include "AntiAliasTable.h"
#include "RGBAColor.h"
// TODO: This is not gamma correct... do we care?
// TODO: This is not gamma correct...
namespace PortabilityLayer
{
#if 0
void AntiAliasTable::GenerateForPalette(const RGBAColor &baseColorRef, const RGBAColor *colors, size_t numColors)
{
const RGBAColor baseColor = baseColorRef;
@@ -53,4 +54,67 @@ namespace PortabilityLayer
}
}
}
#else
void AntiAliasTable::GenerateForPalette(const RGBAColor &baseColorRef, const RGBAColor *colors, size_t numColors)
{
const RGBAColor baseColor = baseColorRef;
if (numColors > 256)
numColors = 256;
unsigned int baseCh[3] = { baseColor.r, baseColor.g, baseColor.b };
unsigned int baseChLinear[3];
for (int i = 0; i < 3; i++)
baseChLinear[i] = baseCh[i] * baseCh[i];
for (size_t i = 0; i < numColors; i++)
{
const RGBAColor existingColor = colors[i];
unsigned int existingCh[3] = { existingColor.r, existingColor.g, existingColor.b };
unsigned int existingChLinear[3];
for (int i = 0; i < 3; i++)
existingChLinear[i] = existingCh[i] * existingCh[i];
// 0 alpha is always the same color
m_aaTranslate[i][0] = static_cast<uint8_t>(i);
for (unsigned int b = 1; b < 16; b++)
{
uint32_t newChLinear[3];
for (unsigned int ch = 0; ch < 3; ch++)
newChLinear[ch] = (15 - b) * existingChLinear[ch] + b * baseChLinear[ch];
uint64_t bestError = UINT64_MAX;
size_t bestColor = 0;
for (size_t cmp = 0; cmp < numColors; cmp++)
{
int32_t compareColor[3] = { colors[cmp].r, colors[cmp].g, colors[cmp].b };
for (unsigned int ch = 0; ch < 3; ch++)
{
compareColor[ch] = compareColor[ch] * compareColor[ch] * 15;
}
uint64_t error = 0;
for (unsigned int ch = 0; ch < 3; ch++)
{
int64_t delta = static_cast<int32_t>(newChLinear[ch]) - compareColor[ch];
error += static_cast<uint64_t>(delta * delta);
}
if (error < bestError)
{
bestError = error;
bestColor = cmp;
}
}
m_aaTranslate[i][b] = static_cast<uint8_t>(bestColor);
}
}
}
#endif
}

View File

@@ -61,12 +61,12 @@ namespace PortabilityLayer
m_applicationFont = FontFamily::Create();
if (m_systemFont)
m_systemFont->AddFont(FontFamilyFlag_None, "Fonts/Virtue/virtue.ttf", FontHacks_None);
m_systemFont->AddFont(FontFamilyFlag_None, "Fonts/OpenSans/OpenSans-ExtraBold.ttf", FontHacks_None);
if (m_applicationFont)
{
m_applicationFont->AddFont(FontFamilyFlag_None, "Fonts/Roboto/Roboto-Regular.ttf", FontHacks_Roboto);
m_applicationFont->AddFont(FontFamilyFlag_Bold, "Fonts/Roboto/Roboto-Bold.ttf", FontHacks_Roboto);
m_applicationFont->AddFont(FontFamilyFlag_None, "Fonts/OpenSans/OpenSans-SemiBold.ttf", FontHacks_None);
m_applicationFont->AddFont(FontFamilyFlag_Bold, "Fonts/OpenSans/OpenSans-Bold.ttf", FontHacks_None);
}
memset(m_cachedRenderedFonts, 0, sizeof(m_cachedRenderedFonts));

View File

@@ -85,5 +85,5 @@ void HiliteControl(ControlHandle control, int unknown)
void HiliteControl(PortabilityLayer::Widget *widget, int unknown)
{
PL_NotYetImplemented();
PL_NotYetImplemented();
}

View File

@@ -1,88 +1,89 @@
#include "QDStandardPalette.h"
#include <string.h>
#include "QDStandardPalette.h"
#include <string.h>
// Standard palette mapping is 6x6x6, with the last element omitted for an RGB table
// which ranges from 0..214
// 10 elements of red scale from 215..224
// 10 elements of green scale from 225..234
// 10 elements of blue scale from 235..244
// 10 elements of gray scale from 245..254
// black at 255
namespace
{
// black at 255
namespace
{
static void DivMod15By5RoundDown(unsigned int value, unsigned int &valueDiv3Out, unsigned int &valueMod3Out)
{
const unsigned int valueDiv3 = (value * 11) >> 5;
const unsigned int valueMod3 = value - valueDiv3 * 3;
valueDiv3Out = valueDiv3;
valueMod3Out = valueMod3;
}
}
namespace PortabilityLayer
{
StandardPalette::StandardPalette()
{
for (unsigned int rs = 0; rs < 6; rs++)
{
for (unsigned int gs = 0; gs < 6; gs++)
{
for (unsigned int bs = 0; bs < 6; bs++)
{
RGBAColor &entry = m_colors[215 - bs - gs * 6 - rs * 36];
entry.r = rs * 51;
entry.g = gs * 51;
entry.b = bs * 51;
entry.a = 255;
}
}
}
for (unsigned int scale = 0; scale < 5; scale++)
{
for (unsigned int tickUp = 0; tickUp < 2; tickUp++)
{
const unsigned int scaleValue = (scale * 3 + tickUp + 1) * 17;
const unsigned int scaleIndex = scale * 2 + tickUp;
RGBAColor &rScaleEntry = m_colors[224 - scaleIndex];
RGBAColor &gScaleEntry = m_colors[234 - scaleIndex];
RGBAColor &bScaleEntry = m_colors[244 - scaleIndex];
RGBAColor &grayScaleEntry = m_colors[254 - scaleIndex];
rScaleEntry.r = scaleValue;
rScaleEntry.g = 0;
rScaleEntry.b = 0;
rScaleEntry.a = 255;
gScaleEntry.r = 0;
gScaleEntry.g = scaleValue;
gScaleEntry.b = 0;
gScaleEntry.a = 255;
bScaleEntry.r = 0;
bScaleEntry.g = 0;
bScaleEntry.b = scaleValue;
bScaleEntry.a = 255;
grayScaleEntry.r = scaleValue;
grayScaleEntry.g = scaleValue;
grayScaleEntry.b = scaleValue;
grayScaleEntry.a = 255;
}
}
RGBAColor &blackEntry = m_colors[255];
blackEntry.r = blackEntry.g = blackEntry.b = 0;
blackEntry.a = 255;
for (unsigned int rs = 0; rs < 16; rs++)
for (unsigned int gs = 0; gs < 16; gs++)
for (unsigned int bs = 0; bs < 16; bs++)
}
}
namespace PortabilityLayer
{
StandardPalette::StandardPalette()
{
for (unsigned int rs = 0; rs < 6; rs++)
{
for (unsigned int gs = 0; gs < 6; gs++)
{
for (unsigned int bs = 0; bs < 6; bs++)
{
RGBAColor &entry = m_colors[215 - bs - gs * 6 - rs * 36];
entry.r = rs * 51;
entry.g = gs * 51;
entry.b = bs * 51;
entry.a = 255;
}
}
}
for (unsigned int scale = 0; scale < 5; scale++)
{
for (unsigned int tickUp = 0; tickUp < 2; tickUp++)
{
const unsigned int scaleValue = (scale * 3 + tickUp + 1) * 17;
const unsigned int scaleIndex = scale * 2 + tickUp;
RGBAColor &rScaleEntry = m_colors[224 - scaleIndex];
RGBAColor &gScaleEntry = m_colors[234 - scaleIndex];
RGBAColor &bScaleEntry = m_colors[244 - scaleIndex];
RGBAColor &grayScaleEntry = m_colors[254 - scaleIndex];
rScaleEntry.r = scaleValue;
rScaleEntry.g = 0;
rScaleEntry.b = 0;
rScaleEntry.a = 255;
gScaleEntry.r = 0;
gScaleEntry.g = scaleValue;
gScaleEntry.b = 0;
gScaleEntry.a = 255;
bScaleEntry.r = 0;
bScaleEntry.g = 0;
bScaleEntry.b = scaleValue;
bScaleEntry.a = 255;
grayScaleEntry.r = scaleValue;
grayScaleEntry.g = scaleValue;
grayScaleEntry.b = scaleValue;
grayScaleEntry.a = 255;
}
}
RGBAColor &blackEntry = m_colors[255];
blackEntry.r = blackEntry.g = blackEntry.b = 0;
blackEntry.a = 255;
for (unsigned int rs = 0; rs < 16; rs++)
for (unsigned int gs = 0; gs < 16; gs++)
for (unsigned int bs = 0; bs < 16; bs++)
m_lut[rs + (gs << 4) + (bs << 8)] = MapColorAnalyticTruncated(rs, gs, bs);
#if 0
for (unsigned int i = 0; i < 256; i++)
{
unsigned int shortChannels[3] =
@@ -109,15 +110,19 @@ namespace PortabilityLayer
m_blackAATable.m_aaTranslate[i][b] = MapColorAnalyticTruncated(blackScale[0], blackScale[1], blackScale[2]);
m_whiteAATable.m_aaTranslate[i][b] = MapColorAnalyticTruncated(whiteScale[0], whiteScale[1], whiteScale[2]);
}
}
}
const RGBAColor *StandardPalette::GetColors() const
{
return m_colors;
}
uint8_t StandardPalette::MapColorAnalyticTruncated(unsigned int r, unsigned int g, unsigned int b)
}
#else
m_blackAATable.GenerateForPalette(RGBAColor::Create(0, 0, 0, 255), m_colors, 256);
m_whiteAATable.GenerateForPalette(RGBAColor::Create(255, 255, 255, 255), m_colors, 256);
#endif
}
const RGBAColor *StandardPalette::GetColors() const
{
return m_colors;
}
uint8_t StandardPalette::MapColorAnalyticTruncated(unsigned int r, unsigned int g, unsigned int b)
{
if (g <= 1 && b <= 1)
{
@@ -215,58 +220,58 @@ namespace PortabilityLayer
if ((rSmallNearest6 | gSmallNearest6 | bSmallNearest6) == 0)
return 255;
else
return 215 - bSmallNearest6 - gSmallNearest6 * 6 - rSmallNearest6 * 36;
}
uint8_t StandardPalette::MapColorAnalytic(uint8_t r, uint8_t g, uint8_t b)
{
return 215 - bSmallNearest6 - gSmallNearest6 * 6 - rSmallNearest6 * 36;
}
uint8_t StandardPalette::MapColorAnalytic(uint8_t r, uint8_t g, uint8_t b)
{
// Round to 0..15 range
const unsigned int rSmall = (r * 241 + 2048) >> 12;
const unsigned int gSmall = (g * 241 + 2048) >> 12;
const unsigned int bSmall = (b * 241 + 2048) >> 12;
return MapColorAnalyticTruncated(rSmall, gSmall, bSmall);
}
uint8_t StandardPalette::MapColorAnalytic(const RGBAColor &color)
{
const unsigned int bSmall = (b * 241 + 2048) >> 12;
return MapColorAnalyticTruncated(rSmall, gSmall, bSmall);
}
uint8_t StandardPalette::MapColorAnalytic(const RGBAColor &color)
{
// Round to 0..15 range
const unsigned int rSmall = (color.r * 241 + 2048) >> 12;
const unsigned int gSmall = (color.g * 241 + 2048) >> 12;
const unsigned int bSmall = (color.b * 241 + 2048) >> 12;
return MapColorAnalyticTruncated(rSmall, gSmall, bSmall);
}
uint8_t StandardPalette::MapColorLUT(uint8_t r, uint8_t g, uint8_t b) const
{
const unsigned int bSmall = (color.b * 241 + 2048) >> 12;
return MapColorAnalyticTruncated(rSmall, gSmall, bSmall);
}
uint8_t StandardPalette::MapColorLUT(uint8_t r, uint8_t g, uint8_t b) const
{
// Round to 0..15 range
const unsigned int rSmall = (r * 241 + 2048) >> 12;
const unsigned int gSmall = (g * 241 + 2048) >> 12;
const unsigned int bSmall = (b * 241 + 2048) >> 12;
return m_lut[rSmall + (gSmall << 4) + (bSmall << 8)];
}
uint8_t StandardPalette::MapColorLUT(const RGBAColor &color) const
{
return MapColorLUT(color.r, color.g, color.b);
}
const StandardPalette *StandardPalette::GetInstance()
{
return &ms_instance;
const unsigned int bSmall = (b * 241 + 2048) >> 12;
return m_lut[rSmall + (gSmall << 4) + (bSmall << 8)];
}
uint8_t StandardPalette::MapColorLUT(const RGBAColor &color) const
{
return MapColorLUT(color.r, color.g, color.b);
}
const StandardPalette *StandardPalette::GetInstance()
{
return &ms_instance;
}
const AntiAliasTable &StandardPalette::GetWhiteAATable() const
{
return m_whiteAATable;
{
return m_whiteAATable;
}
const AntiAliasTable &StandardPalette::GetBlackAATable() const
{
return m_blackAATable;
}
StandardPalette StandardPalette::ms_instance;
}
{
return m_blackAATable;
}
StandardPalette StandardPalette::ms_instance;
}

View File

@@ -1,36 +1,36 @@
#pragma once
#pragma once
#include "AntiAliasTable.h"
#include "RGBAColor.h"
namespace PortabilityLayer
#include "AntiAliasTable.h"
#include "RGBAColor.h"
namespace PortabilityLayer
{
struct AntiAliasTable;
class StandardPalette
{
public:
static const unsigned int kSize = 256;
StandardPalette();
const RGBAColor *GetColors() const;
static uint8_t MapColorAnalyticTruncated(unsigned int r, unsigned int g, unsigned int b);
static uint8_t MapColorAnalytic(uint8_t r, uint8_t g, uint8_t b);
static uint8_t MapColorAnalytic(const RGBAColor &color);
uint8_t MapColorLUT(uint8_t r, uint8_t g, uint8_t b) const;
class StandardPalette
{
public:
static const unsigned int kSize = 256;
StandardPalette();
const RGBAColor *GetColors() const;
static uint8_t MapColorAnalyticTruncated(unsigned int r, unsigned int g, unsigned int b);
static uint8_t MapColorAnalytic(uint8_t r, uint8_t g, uint8_t b);
static uint8_t MapColorAnalytic(const RGBAColor &color);
uint8_t MapColorLUT(uint8_t r, uint8_t g, uint8_t b) const;
uint8_t MapColorLUT(const RGBAColor &color) const;
const AntiAliasTable &GetWhiteAATable() const;
const AntiAliasTable &GetBlackAATable() const;
static const StandardPalette *GetInstance();
private:
static StandardPalette ms_instance;
const AntiAliasTable &GetWhiteAATable() const;
const AntiAliasTable &GetBlackAATable() const;
static const StandardPalette *GetInstance();
private:
static StandardPalette ms_instance;
RGBAColor m_colors[kSize];
AntiAliasTable m_whiteAATable;
AntiAliasTable m_blackAATable;
uint8_t m_lut[16 * 16 * 16];
};
}
AntiAliasTable m_whiteAATable;
AntiAliasTable m_blackAATable;
uint8_t m_lut[16 * 16 * 16];
};
}