allow testing more font properties: light weight, slant style and font families
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@60117 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -101,7 +101,11 @@ public:
|
|||||||
void OnDecFont(wxCommandEvent& WXUNUSED(event)) { DoResizeFont(-2); }
|
void OnDecFont(wxCommandEvent& WXUNUSED(event)) { DoResizeFont(-2); }
|
||||||
|
|
||||||
void OnBold(wxCommandEvent& event);
|
void OnBold(wxCommandEvent& event);
|
||||||
|
void OnLight(wxCommandEvent& event);
|
||||||
|
|
||||||
void OnItalic(wxCommandEvent& event);
|
void OnItalic(wxCommandEvent& event);
|
||||||
|
void OnSlant(wxCommandEvent& event);
|
||||||
|
|
||||||
void OnUnderline(wxCommandEvent& event);
|
void OnUnderline(wxCommandEvent& event);
|
||||||
|
|
||||||
void OnwxPointerFont(wxCommandEvent& event);
|
void OnwxPointerFont(wxCommandEvent& event);
|
||||||
@@ -119,6 +123,8 @@ public:
|
|||||||
|
|
||||||
void OnSetNativeDesc(wxCommandEvent& event);
|
void OnSetNativeDesc(wxCommandEvent& event);
|
||||||
void OnSetNativeUserDesc(wxCommandEvent& event);
|
void OnSetNativeUserDesc(wxCommandEvent& event);
|
||||||
|
|
||||||
|
void OnSetFamily(wxCommandEvent& event);
|
||||||
void OnSetFaceName(wxCommandEvent& event);
|
void OnSetFaceName(wxCommandEvent& event);
|
||||||
void OnSetEncoding(wxCommandEvent& event);
|
void OnSetEncoding(wxCommandEvent& event);
|
||||||
|
|
||||||
@@ -134,6 +140,9 @@ protected:
|
|||||||
// wxFONTENCODING_SYSTEM if the dialog was cancelled
|
// wxFONTENCODING_SYSTEM if the dialog was cancelled
|
||||||
wxFontEncoding GetEncodingFromUser();
|
wxFontEncoding GetEncodingFromUser();
|
||||||
|
|
||||||
|
// ask the user to choose a font family and return it or
|
||||||
|
// wxFONTFAMILY_DEFAULT if the dialog was cancelled
|
||||||
|
wxFontFamily GetFamilyFromUser();
|
||||||
|
|
||||||
size_t m_fontSize; // in points
|
size_t m_fontSize; // in points
|
||||||
|
|
||||||
@@ -161,8 +170,13 @@ enum
|
|||||||
|
|
||||||
Font_IncSize,
|
Font_IncSize,
|
||||||
Font_DecSize,
|
Font_DecSize,
|
||||||
|
|
||||||
Font_Bold,
|
Font_Bold,
|
||||||
|
Font_Light,
|
||||||
|
|
||||||
Font_Italic,
|
Font_Italic,
|
||||||
|
Font_Slant,
|
||||||
|
|
||||||
Font_Underlined,
|
Font_Underlined,
|
||||||
|
|
||||||
// standard global wxFont objects:
|
// standard global wxFont objects:
|
||||||
@@ -179,6 +193,7 @@ enum
|
|||||||
Font_wxSYS_SYSTEM_FONT,
|
Font_wxSYS_SYSTEM_FONT,
|
||||||
Font_wxSYS_DEVICE_DEFAULT_FONT,
|
Font_wxSYS_DEVICE_DEFAULT_FONT,
|
||||||
Font_wxSYS_DEFAULT_GUI_FONT,
|
Font_wxSYS_DEFAULT_GUI_FONT,
|
||||||
|
Font_SystemSettings,
|
||||||
|
|
||||||
Font_Choose = 100,
|
Font_Choose = 100,
|
||||||
Font_EnumFamiliesForEncoding,
|
Font_EnumFamiliesForEncoding,
|
||||||
@@ -187,6 +202,7 @@ enum
|
|||||||
Font_EnumEncodings,
|
Font_EnumEncodings,
|
||||||
Font_SetNativeDesc,
|
Font_SetNativeDesc,
|
||||||
Font_SetNativeUserDesc,
|
Font_SetNativeUserDesc,
|
||||||
|
Font_SetFamily,
|
||||||
Font_SetFaceName,
|
Font_SetFaceName,
|
||||||
Font_SetEncoding,
|
Font_SetEncoding,
|
||||||
Font_Max
|
Font_Max
|
||||||
@@ -207,8 +223,13 @@ BEGIN_EVENT_TABLE(MyFrame, wxFrame)
|
|||||||
|
|
||||||
EVT_MENU(Font_IncSize, MyFrame::OnIncFont)
|
EVT_MENU(Font_IncSize, MyFrame::OnIncFont)
|
||||||
EVT_MENU(Font_DecSize, MyFrame::OnDecFont)
|
EVT_MENU(Font_DecSize, MyFrame::OnDecFont)
|
||||||
|
|
||||||
EVT_MENU(Font_Bold, MyFrame::OnBold)
|
EVT_MENU(Font_Bold, MyFrame::OnBold)
|
||||||
|
EVT_MENU(Font_Light, MyFrame::OnLight)
|
||||||
|
|
||||||
EVT_MENU(Font_Italic, MyFrame::OnItalic)
|
EVT_MENU(Font_Italic, MyFrame::OnItalic)
|
||||||
|
EVT_MENU(Font_Slant, MyFrame::OnSlant)
|
||||||
|
|
||||||
EVT_MENU(Font_Underlined, MyFrame::OnUnderline)
|
EVT_MENU(Font_Underlined, MyFrame::OnUnderline)
|
||||||
|
|
||||||
EVT_MENU(Font_wxNORMAL_FONT, MyFrame::OnwxPointerFont)
|
EVT_MENU(Font_wxNORMAL_FONT, MyFrame::OnwxPointerFont)
|
||||||
@@ -225,6 +246,7 @@ BEGIN_EVENT_TABLE(MyFrame, wxFrame)
|
|||||||
|
|
||||||
EVT_MENU(Font_SetNativeDesc, MyFrame::OnSetNativeDesc)
|
EVT_MENU(Font_SetNativeDesc, MyFrame::OnSetNativeDesc)
|
||||||
EVT_MENU(Font_SetNativeUserDesc, MyFrame::OnSetNativeUserDesc)
|
EVT_MENU(Font_SetNativeUserDesc, MyFrame::OnSetNativeUserDesc)
|
||||||
|
EVT_MENU(Font_SetFamily, MyFrame::OnSetFamily)
|
||||||
EVT_MENU(Font_SetFaceName, MyFrame::OnSetFaceName)
|
EVT_MENU(Font_SetFaceName, MyFrame::OnSetFaceName)
|
||||||
EVT_MENU(Font_SetEncoding, MyFrame::OnSetEncoding)
|
EVT_MENU(Font_SetEncoding, MyFrame::OnSetEncoding)
|
||||||
|
|
||||||
@@ -299,42 +321,51 @@ MyFrame::MyFrame(const wxString& title, const wxPoint& pos, const wxSize& size)
|
|||||||
menuFont->Append(Font_DecSize, wxT("&Decrease font size by 2 points\tCtrl-D"));
|
menuFont->Append(Font_DecSize, wxT("&Decrease font size by 2 points\tCtrl-D"));
|
||||||
menuFont->AppendSeparator();
|
menuFont->AppendSeparator();
|
||||||
menuFont->AppendCheckItem(Font_Bold, wxT("&Bold\tCtrl-B"), wxT("Toggle bold state"));
|
menuFont->AppendCheckItem(Font_Bold, wxT("&Bold\tCtrl-B"), wxT("Toggle bold state"));
|
||||||
|
menuFont->AppendCheckItem(Font_Light, wxT("&Light\tCtrl-L"), wxT("Toggle light state"));
|
||||||
|
menuFont->AppendSeparator();
|
||||||
menuFont->AppendCheckItem(Font_Italic, wxT("&Oblique\tCtrl-O"), wxT("Toggle italic state"));
|
menuFont->AppendCheckItem(Font_Italic, wxT("&Oblique\tCtrl-O"), wxT("Toggle italic state"));
|
||||||
|
menuFont->AppendCheckItem(Font_Slant, wxT("&Slant\tCtrl-S"), wxT("Toggle slant state"));
|
||||||
|
menuFont->AppendSeparator();
|
||||||
menuFont->AppendCheckItem(Font_Underlined, wxT("&Underlined\tCtrl-U"),
|
menuFont->AppendCheckItem(Font_Underlined, wxT("&Underlined\tCtrl-U"),
|
||||||
wxT("Toggle underlined state"));
|
wxT("Toggle underlined state"));
|
||||||
|
|
||||||
menuFont->AppendSeparator();
|
menuFont->AppendSeparator();
|
||||||
menuFont->Append(Font_SetNativeDesc,
|
menuFont->Append(Font_SetNativeDesc,
|
||||||
wxT("Set native font &description\tShift-Ctrl-D"));
|
wxT("Set native font &description\tShift-Ctrl-D"));
|
||||||
menuFont->Append(Font_SetNativeUserDesc,
|
menuFont->Append(Font_SetNativeUserDesc,
|
||||||
wxT("Set &user font description\tShift-Ctrl-U"));
|
wxT("Set &user font description\tShift-Ctrl-U"));
|
||||||
menuFont->Append(Font_SetFaceName, wxT("Check font face name"));
|
menuFont->AppendSeparator();
|
||||||
|
menuFont->Append(Font_SetFamily, wxT("Set font family"));
|
||||||
|
menuFont->Append(Font_SetFaceName, wxT("Set font face name"));
|
||||||
menuFont->Append(Font_SetEncoding, wxT("Set font &encoding\tShift-Ctrl-E"));
|
menuFont->Append(Font_SetEncoding, wxT("Set font &encoding\tShift-Ctrl-E"));
|
||||||
|
|
||||||
wxMenu *menuSelect = new wxMenu;
|
wxMenu *menuSelect = new wxMenu;
|
||||||
menuSelect->Append(Font_Choose, wxT("&Select font...\tCtrl-S"),
|
menuSelect->Append(Font_Choose, wxT("&Select font...\tCtrl-S"),
|
||||||
wxT("Select a standard font"));
|
wxT("Select a standard font"));
|
||||||
|
|
||||||
wxMenu *menuStdFonts = new wxMenu;
|
wxMenu *menuStdFonts = new wxMenu;
|
||||||
menuStdFonts->Append(Font_wxNORMAL_FONT, wxT("wxNORMAL_FONT"), wxT("Normal font used by wxWidgets"));
|
menuStdFonts->Append(Font_wxNORMAL_FONT, wxT("wxNORMAL_FONT"), wxT("Normal font used by wxWidgets"));
|
||||||
menuStdFonts->Append(Font_wxSMALL_FONT, wxT("wxSMALL_FONT"), wxT("Small font used by wxWidgets"));
|
menuStdFonts->Append(Font_wxSMALL_FONT, wxT("wxSMALL_FONT"), wxT("Small font used by wxWidgets"));
|
||||||
menuStdFonts->Append(Font_wxITALIC_FONT, wxT("wxITALIC_FONT"), wxT("Italic font used by wxWidgets"));
|
menuStdFonts->Append(Font_wxITALIC_FONT, wxT("wxITALIC_FONT"), wxT("Italic font used by wxWidgets"));
|
||||||
menuStdFonts->Append(Font_wxSWISS_FONT, wxT("wxSWISS_FONT"), wxT("Swiss font used by wxWidgets"));
|
menuStdFonts->Append(Font_wxSWISS_FONT, wxT("wxSWISS_FONT"), wxT("Swiss font used by wxWidgets"));
|
||||||
menuStdFonts->AppendSeparator();
|
|
||||||
menuStdFonts->Append(Font_wxSYS_OEM_FIXED_FONT, wxT("wxSYS_OEM_FIXED_FONT"),
|
|
||||||
wxT("Original equipment manufacturer dependent fixed-pitch font."));
|
|
||||||
menuStdFonts->Append(Font_wxSYS_ANSI_FIXED_FONT, wxT("wxSYS_ANSI_FIXED_FONT"),
|
|
||||||
wxT("Windows fixed-pitch (monospaced) font. "));
|
|
||||||
menuStdFonts->Append(Font_wxSYS_ANSI_VAR_FONT, wxT("wxSYS_ANSI_VAR_FONT"),
|
|
||||||
wxT("Windows variable-pitch (proportional) font."));
|
|
||||||
menuStdFonts->Append(Font_wxSYS_SYSTEM_FONT, wxT("wxSYS_SYSTEM_FONT"),
|
|
||||||
wxT("System font."));
|
|
||||||
menuStdFonts->Append(Font_wxSYS_DEVICE_DEFAULT_FONT, wxT("wxSYS_DEVICE_DEFAULT_FONT"),
|
|
||||||
wxT("Device-dependent font."));
|
|
||||||
menuStdFonts->Append(Font_wxSYS_DEFAULT_GUI_FONT, wxT("wxSYS_DEFAULT_GUI_FONT"),
|
|
||||||
wxT("Default font for user interface objects such as menus and dialog boxes. "));
|
|
||||||
menuSelect->Append(Font_Standard, wxT("Standar&d fonts"), menuStdFonts);
|
menuSelect->Append(Font_Standard, wxT("Standar&d fonts"), menuStdFonts);
|
||||||
|
|
||||||
|
wxMenu *menuSettingFonts = new wxMenu;
|
||||||
|
menuSettingFonts->Append(Font_wxSYS_OEM_FIXED_FONT, wxT("wxSYS_OEM_FIXED_FONT"),
|
||||||
|
wxT("Original equipment manufacturer dependent fixed-pitch font."));
|
||||||
|
menuSettingFonts->Append(Font_wxSYS_ANSI_FIXED_FONT, wxT("wxSYS_ANSI_FIXED_FONT"),
|
||||||
|
wxT("Windows fixed-pitch (monospaced) font. "));
|
||||||
|
menuSettingFonts->Append(Font_wxSYS_ANSI_VAR_FONT, wxT("wxSYS_ANSI_VAR_FONT"),
|
||||||
|
wxT("Windows variable-pitch (proportional) font."));
|
||||||
|
menuSettingFonts->Append(Font_wxSYS_SYSTEM_FONT, wxT("wxSYS_SYSTEM_FONT"),
|
||||||
|
wxT("System font."));
|
||||||
|
menuSettingFonts->Append(Font_wxSYS_DEVICE_DEFAULT_FONT, wxT("wxSYS_DEVICE_DEFAULT_FONT"),
|
||||||
|
wxT("Device-dependent font."));
|
||||||
|
menuSettingFonts->Append(Font_wxSYS_DEFAULT_GUI_FONT, wxT("wxSYS_DEFAULT_GUI_FONT"),
|
||||||
|
wxT("Default font for user interface objects such as menus and dialog boxes. "));
|
||||||
|
menuSelect->Append(Font_SystemSettings, wxT("System fonts"), menuSettingFonts);
|
||||||
|
|
||||||
|
|
||||||
menuSelect->AppendSeparator();
|
menuSelect->AppendSeparator();
|
||||||
menuSelect->Append(Font_EnumFamilies, wxT("Enumerate font &families\tCtrl-F"));
|
menuSelect->Append(Font_EnumFamilies, wxT("Enumerate font &families\tCtrl-F"));
|
||||||
menuSelect->Append(Font_EnumFixedFamilies,
|
menuSelect->Append(Font_EnumFixedFamilies,
|
||||||
@@ -530,6 +561,38 @@ void MyFrame::OnSetNativeDesc(wxCommandEvent& WXUNUSED(event))
|
|||||||
DoChangeFont(font);
|
DoChangeFont(font);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MyFrame::OnSetNativeUserDesc(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
wxString fontdesc = GetCanvas()->GetTextFont().GetNativeFontInfoUserDesc();
|
||||||
|
wxString fontUserInfo = wxGetTextFromUser(
|
||||||
|
wxT("Here you can edit current font description"),
|
||||||
|
wxT("Input font description"), fontdesc,
|
||||||
|
this);
|
||||||
|
if (fontUserInfo.IsEmpty())
|
||||||
|
return; // user clicked "Cancel" - do nothing
|
||||||
|
|
||||||
|
wxFont font;
|
||||||
|
if (font.SetNativeFontInfoUserDesc(fontUserInfo))
|
||||||
|
{
|
||||||
|
wxASSERT_MSG(font.Ok(), wxT("The font should now be valid"));
|
||||||
|
DoChangeFont(font);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
wxASSERT_MSG(!font.Ok(), wxT("The font should now be invalid"));
|
||||||
|
wxMessageBox(wxT("Error trying to create a font with such description..."));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void MyFrame::OnSetFamily(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
wxFontFamily f = GetFamilyFromUser();
|
||||||
|
|
||||||
|
wxFont font = m_canvas->GetTextFont();
|
||||||
|
font.SetFamily(f);
|
||||||
|
DoChangeFont(font);
|
||||||
|
}
|
||||||
|
|
||||||
void MyFrame::OnSetFaceName(wxCommandEvent& WXUNUSED(event))
|
void MyFrame::OnSetFaceName(wxCommandEvent& WXUNUSED(event))
|
||||||
{
|
{
|
||||||
wxString facename = GetCanvas()->GetTextFont().GetFaceName();
|
wxString facename = GetCanvas()->GetTextFont().GetFaceName();
|
||||||
@@ -554,29 +617,6 @@ void MyFrame::OnSetFaceName(wxCommandEvent& WXUNUSED(event))
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void MyFrame::OnSetNativeUserDesc(wxCommandEvent& WXUNUSED(event))
|
|
||||||
{
|
|
||||||
wxString fontdesc = GetCanvas()->GetTextFont().GetNativeFontInfoUserDesc();
|
|
||||||
wxString fontUserInfo = wxGetTextFromUser(
|
|
||||||
wxT("Here you can edit current font description"),
|
|
||||||
wxT("Input font description"), fontdesc,
|
|
||||||
this);
|
|
||||||
if (fontUserInfo.IsEmpty())
|
|
||||||
return; // user clicked "Cancel" - do nothing
|
|
||||||
|
|
||||||
wxFont font;
|
|
||||||
if (font.SetNativeFontInfoUserDesc(fontUserInfo))
|
|
||||||
{
|
|
||||||
wxASSERT_MSG(font.Ok(), wxT("The font should now be valid"));
|
|
||||||
DoChangeFont(font);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
wxASSERT_MSG(!font.Ok(), wxT("The font should now be invalid"));
|
|
||||||
wxMessageBox(wxT("Error trying to create a font with such description..."));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void MyFrame::OnSetEncoding(wxCommandEvent& WXUNUSED(event))
|
void MyFrame::OnSetEncoding(wxCommandEvent& WXUNUSED(event))
|
||||||
{
|
{
|
||||||
wxFontEncoding enc = GetEncodingFromUser();
|
wxFontEncoding enc = GetEncodingFromUser();
|
||||||
@@ -615,6 +655,36 @@ wxFontEncoding MyFrame::GetEncodingFromUser()
|
|||||||
return i == -1 ? wxFONTENCODING_SYSTEM : (wxFontEncoding)encodings[i];
|
return i == -1 ? wxFONTENCODING_SYSTEM : (wxFontEncoding)encodings[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
wxFontFamily MyFrame::GetFamilyFromUser()
|
||||||
|
{
|
||||||
|
wxArrayString names;
|
||||||
|
wxArrayInt families;
|
||||||
|
|
||||||
|
families.push_back(wxFONTFAMILY_DECORATIVE);
|
||||||
|
families.push_back(wxFONTFAMILY_ROMAN);
|
||||||
|
families.push_back(wxFONTFAMILY_SCRIPT);
|
||||||
|
families.push_back(wxFONTFAMILY_SWISS);
|
||||||
|
families.push_back(wxFONTFAMILY_MODERN);
|
||||||
|
families.push_back(wxFONTFAMILY_TELETYPE);
|
||||||
|
|
||||||
|
names.push_back("DECORATIVE");
|
||||||
|
names.push_back("ROMAN");
|
||||||
|
names.push_back("SCRIPT");
|
||||||
|
names.push_back("SWISS");
|
||||||
|
names.push_back("MODERN");
|
||||||
|
names.push_back("TELETYPE");
|
||||||
|
|
||||||
|
int i = wxGetSingleChoiceIndex
|
||||||
|
(
|
||||||
|
wxT("Choose the family"),
|
||||||
|
SAMPLE_TITLE,
|
||||||
|
names,
|
||||||
|
this
|
||||||
|
);
|
||||||
|
|
||||||
|
return i == -1 ? wxFONTFAMILY_DEFAULT : (wxFontFamily)families[i];
|
||||||
|
}
|
||||||
|
|
||||||
void MyFrame::DoResizeFont(int diff)
|
void MyFrame::DoResizeFont(int diff)
|
||||||
{
|
{
|
||||||
wxFont font = m_canvas->GetTextFont();
|
wxFont font = m_canvas->GetTextFont();
|
||||||
@@ -631,6 +701,14 @@ void MyFrame::OnBold(wxCommandEvent& event)
|
|||||||
DoChangeFont(font);
|
DoChangeFont(font);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MyFrame::OnLight(wxCommandEvent& event)
|
||||||
|
{
|
||||||
|
wxFont font = m_canvas->GetTextFont();
|
||||||
|
|
||||||
|
font.SetWeight(event.IsChecked() ? wxFONTWEIGHT_LIGHT : wxFONTWEIGHT_NORMAL);
|
||||||
|
DoChangeFont(font);
|
||||||
|
}
|
||||||
|
|
||||||
void MyFrame::OnItalic(wxCommandEvent& event)
|
void MyFrame::OnItalic(wxCommandEvent& event)
|
||||||
{
|
{
|
||||||
wxFont font = m_canvas->GetTextFont();
|
wxFont font = m_canvas->GetTextFont();
|
||||||
@@ -639,6 +717,14 @@ void MyFrame::OnItalic(wxCommandEvent& event)
|
|||||||
DoChangeFont(font);
|
DoChangeFont(font);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MyFrame::OnSlant(wxCommandEvent& event)
|
||||||
|
{
|
||||||
|
wxFont font = m_canvas->GetTextFont();
|
||||||
|
|
||||||
|
font.SetStyle(event.IsChecked() ? wxFONTSTYLE_SLANT : wxFONTSTYLE_NORMAL);
|
||||||
|
DoChangeFont(font);
|
||||||
|
}
|
||||||
|
|
||||||
void MyFrame::OnUnderline(wxCommandEvent& event)
|
void MyFrame::OnUnderline(wxCommandEvent& event)
|
||||||
{
|
{
|
||||||
wxFont font = m_canvas->GetTextFont();
|
wxFont font = m_canvas->GetTextFont();
|
||||||
@@ -730,8 +816,12 @@ void MyFrame::DoChangeFont(const wxFont& font, const wxColour& col)
|
|||||||
wxMenuBar *mbar = GetMenuBar();
|
wxMenuBar *mbar = GetMenuBar();
|
||||||
if ( mbar )
|
if ( mbar )
|
||||||
{
|
{
|
||||||
|
mbar->Check(Font_Light, font.GetWeight() == wxFONTWEIGHT_LIGHT);
|
||||||
mbar->Check(Font_Bold, font.GetWeight() == wxFONTWEIGHT_BOLD);
|
mbar->Check(Font_Bold, font.GetWeight() == wxFONTWEIGHT_BOLD);
|
||||||
|
|
||||||
mbar->Check(Font_Italic, font.GetStyle() == wxFONTSTYLE_ITALIC);
|
mbar->Check(Font_Italic, font.GetStyle() == wxFONTSTYLE_ITALIC);
|
||||||
|
mbar->Check(Font_Slant, font.GetStyle() == wxFONTSTYLE_SLANT);
|
||||||
|
|
||||||
mbar->Check(Font_Underlined, font.GetUnderlined());
|
mbar->Check(Font_Underlined, font.GetUnderlined());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user