Add a wxHtmlTag helper parsing both absolute values and percents.

This allows to avoid some code duplication in different handlers.

Closes #14868.

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@73142 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
2012-12-08 00:37:21 +00:00
parent 935693c484
commit e0e4b2b0e9
4 changed files with 54 additions and 21 deletions

View File

@@ -104,6 +104,8 @@ public:
// Convenience functions:
bool GetParamAsColour(const wxString& par, wxColour *clr) const;
bool GetParamAsInt(const wxString& par, int *clr) const;
bool GetParamAsIntOrPercent(const wxString& param,
int* value, bool& isPercent) const;
// Scans param like scanf() functions family does.
// Example : ScanParam("COLOR", "\"#%X\"", &clr);

View File

@@ -587,6 +587,38 @@ bool wxHtmlTag::GetParamAsInt(const wxString& par, int *clr) const
return true;
}
bool
wxHtmlTag::GetParamAsIntOrPercent(const wxString& par,
int* value,
bool& isPercent) const
{
const wxString param = GetParam(par);
if ( param.empty() )
return false;
wxString num;
if ( param.EndsWith("%", &num) )
{
isPercent = true;
}
else
{
isPercent = false;
num = param;
}
long lValue;
if ( !num.ToLong(&lValue) )
return false;
if ( lValue > INT_MAX || lValue < INT_MIN )
return false;
*value = static_cast<int>(lValue);
return true;
}
wxString wxHtmlTag::GetAllParams() const
{
// VS: this function is for backward compatibility only,

View File

@@ -676,16 +676,16 @@ TAG_HANDLER_BEGIN(IMG, "IMG,MAP,AREA")
if (tag.HasParam(wxT("WIDTH")))
{
wxString param = tag.GetParam(wxT("WIDTH"));
wxSscanf(param.c_str(), wxT("%i"), &w);
if (param.EndsWith(wxT("%"))) {
if (w < 0)
w = 0;
else if (w > 100)
w = 100;
wpercent = true;
if (tag.GetParamAsIntOrPercent(wxT("WIDTH"), &w, wpercent))
{
if (wpercent)
{
if (w < 0)
w = 0;
else if (w > 100)
w = 100;
}
}
}
if (tag.HasParam(wxT("HEIGHT")))

View File

@@ -702,19 +702,18 @@ TAG_HANDLER_BEGIN(TABLE, "TABLE,TR,TD,TH")
{
if (tag.HasParam(wxT("WIDTH")))
{
wxString wd = tag.GetParam(wxT("WIDTH"));
if (!wd.empty() && wd[wd.length()-1] == wxT('%'))
int width = 0;
bool wpercent = false;
if (tag.GetParamAsIntOrPercent(wxT("WIDTH"), &width, wpercent))
{
int width = 0;
wxSscanf(wd.c_str(), wxT("%i%%"), &width);
m_Table->SetWidthFloat(width, wxHTML_UNITS_PERCENT);
}
else
{
int width = 0;
wxSscanf(wd.c_str(), wxT("%i"), &width);
m_Table->SetWidthFloat((int)(m_WParser->GetPixelScale() * width), wxHTML_UNITS_PIXELS);
if (wpercent)
{
m_Table->SetWidthFloat(width, wxHTML_UNITS_PERCENT);
}
else
{
m_Table->SetWidthFloat((int)(m_WParser->GetPixelScale() * width), wxHTML_UNITS_PIXELS);
}
}
}
else