made fonts available without installing system-wide

This commit is contained in:
TomTkacz
2025-03-12 04:48:33 -05:00
parent 6b0d311dc9
commit ee4cf2d7b4
4 changed files with 56 additions and 7 deletions
+9 -2
View File
@@ -64,7 +64,14 @@
"cmakeCommandArgs": "-DVCPKG_TARGET_TRIPLET=x64-windows-static", "cmakeCommandArgs": "-DVCPKG_TARGET_TRIPLET=x64-windows-static",
"buildCommandArgs": "-v", "buildCommandArgs": "-v",
"ctestCommandArgs": "", "ctestCommandArgs": "",
"inheritEnvironments": [ "msvc_x64_x64" ] "inheritEnvironments": [ "msvc_x64_x64" ],
"variables": [
{
"name": "VCPKG_MANIFEST_FEATURES",
"value": "fonts",
"type": "STRING"
}
]
} }
] ]
} }
+39 -1
View File
@@ -8,7 +8,10 @@
#include <util/prec.hpp> #include <util/prec.hpp>
#include <data/font.hpp> #include <data/font.hpp>
#include <wx/stdpaths.h>
#include <wx/dir.h>
#include <wx/font.h>
// ----------------------------------------------------------------------------- : Font // ----------------------------------------------------------------------------- : Font
Font::Font() Font::Font()
@@ -23,6 +26,41 @@ Font::Font()
, separator_color(Color(0,0,0,128)) , separator_color(Color(0,0,0,128))
, flags(FONT_NORMAL) , flags(FONT_NORMAL)
{} {}
bool Font::PreloadResourceFonts() {
#if wxUSE_PRIVATE_FONTS
wxUniChar pathSeparator = wxFileName::GetPathSeparator();
String appPath( wxFileName(wxStandardPaths::Get().GetExecutablePath()).GetPath() );
String fontsPath = appPath + pathSeparator + "resource" + pathSeparator + "fonts" + pathSeparator;
if (!wxDirExists(fontsPath))
return false;
wxDir fontsDirectory(fontsPath);
vector<String> fontFilePaths;
String fontFileName = "";
// are there any font files in the resource/fonts directory?
if (!fontsDirectory.GetFirst(&fontFileName, "*.ttf"))
return false;
fontFilePaths.push_back(fontsPath + fontFileName);
while (fontsDirectory.GetNext(&fontFileName))
fontFilePaths.push_back(fontsPath + fontFileName);
bool preloadHadErrors = false;
for (String fn : fontFilePaths) {
if (!wxFont::AddPrivateFont(fn)) {
preloadHadErrors = true;
continue;
}
}
return preloadHadErrors;
#endif // wxUSE_PRIVATE_FONTS
return false;
}
bool Font::update(Context& ctx) { bool Font::update(Context& ctx) {
bool changes = false; bool changes = false;
+6 -4
View File
@@ -45,10 +45,12 @@ public:
RealSize shadow_displacement; ///< Position of the shadow RealSize shadow_displacement; ///< Position of the shadow
double shadow_blur; ///< Blur radius of the shadow double shadow_blur; ///< Blur radius of the shadow
Color separator_color; ///< Color for <sep> text Color separator_color; ///< Color for <sep> text
int flags; ///< FontFlags for this font int flags; ///< FontFlags for this font
Font(); Font();
/// Load fonts (.ttf) from the resource/fonts directory
static bool PreloadResourceFonts();
/// Update the scritables, returns true if there is a change /// Update the scritables, returns true if there is a change
bool update(Context& ctx); bool update(Context& ctx);
/// Add the given dependency to the dependent_scripts list for the variables this font depends on /// Add the given dependency to the dependent_scripts list for the variables this font depends on
@@ -64,7 +66,7 @@ public:
/// Convert this font to a wxFont /// Convert this font to a wxFont
wxFont toWxFont(double scale) const; wxFont toWxFont(double scale) const;
private: private:
DECLARE_REFLECTION(); DECLARE_REFLECTION();
}; };
+2
View File
@@ -15,6 +15,7 @@
#include <data/locale.hpp> #include <data/locale.hpp>
#include <data/installer.hpp> #include <data/installer.hpp>
#include <data/format/formats.hpp> #include <data/format/formats.hpp>
#include <data/font.hpp>
#include <cli/cli_main.hpp> #include <cli/cli_main.hpp>
#include <cli/text_io_handler.hpp> #include <cli/text_io_handler.hpp>
#include <gui/welcome_window.hpp> #include <gui/welcome_window.hpp>
@@ -86,6 +87,7 @@ int MSE::OnRun() {
// Platform friendly appname // Platform friendly appname
SetAppName(_("magicseteditor")); SetAppName(_("magicseteditor"));
#endif #endif
Font::PreloadResourceFonts();
wxInitAllImageHandlers(); wxInitAllImageHandlers();
wxFileSystem::AddHandler(new wxInternetFSHandler); // needed for update checker wxFileSystem::AddHandler(new wxInternetFSHandler); // needed for update checker
wxSocketBase::Initialize(); wxSocketBase::Initialize();