Added conversion of menu labels (&->~)

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@6826 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Stefan Neis
2000-03-18 17:39:14 +00:00
parent 90cfeaab3f
commit 2b33b72819
2 changed files with 109 additions and 16 deletions

View File

@@ -55,6 +55,44 @@ static const int idMenuTitle = -2;
IMPLEMENT_DYNAMIC_CLASS(wxMenu, wxEvtHandler) IMPLEMENT_DYNAMIC_CLASS(wxMenu, wxEvtHandler)
IMPLEMENT_DYNAMIC_CLASS(wxMenuBar, wxEvtHandler) IMPLEMENT_DYNAMIC_CLASS(wxMenuBar, wxEvtHandler)
// ----------------------------------------------------------------------------
// static function for translating menu labels
// ----------------------------------------------------------------------------
static wxString TextToLabel(const wxString& rTitle)
{
wxString Title;
const wxChar *pc;
for (pc = rTitle; *pc != wxT('\0'); pc++ )
{
if (*pc == wxT('&') )
{
if (*(pc+1) == wxT('&'))
{
pc++;
Title << wxT('&');
}
else
Title << wxT('~');
}
// else if (*pc == wxT('/'))
// {
// Title << wxT('\\');
// }
else
{
if ( *pc == wxT('~') )
{
// tildes must be doubled to prevent them from being
// interpreted as accelerator character prefix by PM ???
Title << *pc;
}
Title << *pc;
}
}
return Title;
}
// ============================================================================ // ============================================================================
// implementation // implementation
// ============================================================================ // ============================================================================
@@ -793,9 +831,10 @@ wxMenu* wxMenuBar::Replace(
) )
{ {
SHORT nId; SHORT nId;
wxString Title = TextToLabel(rTitle);
wxMenu* pMenuOld = wxMenuBarBase::Replace( nPos wxMenu* pMenuOld = wxMenuBarBase::Replace( nPos
,pMenu ,pMenu
,rTitle ,Title
); );
@@ -807,11 +846,11 @@ wxMenu* wxMenuBar::Replace(
} }
if (!pMenuOld) if (!pMenuOld)
return FALSE; return FALSE;
m_titles[nPos] = rTitle; m_titles[nPos] = Title;
if (IsAttached()) if (IsAttached())
{ {
::WinSendMsg((HWND)m_hMenu, MM_DELETEITEM, MPFROM2SHORT(nId, TRUE), (MPARAM)0); ::WinSendMsg((HWND)m_hMenu, MM_DELETEITEM, MPFROM2SHORT(nId, TRUE), (MPARAM)0);
::WinSendMsg((HWND)m_hMenu, MM_INSERTITEM, (MPARAM)&pMenu->m_vMenuData, (MPARAM)rTitle.c_str()); ::WinSendMsg((HWND)m_hMenu, MM_INSERTITEM, (MPARAM)&pMenu->m_vMenuData, (MPARAM)Title.c_str());
#if wxUSE_ACCEL #if wxUSE_ACCEL
if (pMenuOld->HasAccels() || pMenu->HasAccels()) if (pMenuOld->HasAccels() || pMenu->HasAccels())
@@ -833,13 +872,14 @@ bool wxMenuBar::Insert(
, const wxString& rTitle , const wxString& rTitle
) )
{ {
wxString Title = TextToLabel(rTitle);
if (!wxMenuBarBase::Insert( nPos if (!wxMenuBarBase::Insert( nPos
,pMenu ,pMenu
,rTitle ,Title
)) ))
return FALSE; return FALSE;
m_titles.Insert( rTitle m_titles.Insert( Title
,nPos ,nPos
); );
@@ -847,7 +887,7 @@ bool wxMenuBar::Insert(
if (IsAttached()) if (IsAttached())
{ {
::WinSendMsg((HWND)m_hMenu, MM_INSERTITEM, (MPARAM)&pMenu->m_vMenuData, (MPARAM)rTitle.c_str()); ::WinSendMsg((HWND)m_hMenu, MM_INSERTITEM, (MPARAM)&pMenu->m_vMenuData, (MPARAM)Title.c_str());
#if wxUSE_ACCEL #if wxUSE_ACCEL
if (pMenu->HasAccels()) if (pMenu->HasAccels())
{ {
@@ -869,16 +909,17 @@ bool wxMenuBar::Append(
wxCHECK_MSG(hSubmenu, FALSE, wxT("can't append invalid menu to menubar")); wxCHECK_MSG(hSubmenu, FALSE, wxT("can't append invalid menu to menubar"));
if (!wxMenuBarBase::Append(pMenu, rTitle)) wxString Title = TextToLabel(rTitle);
if (!wxMenuBarBase::Append(pMenu, Title))
return FALSE; return FALSE;
pMenu->Attach(this); pMenu->Attach(this);
m_titles.Add(rTitle); m_titles.Add(Title);
if ( IsAttached() ) if ( IsAttached() )
{ {
pMenu->m_vMenuData.iPosition = MIT_END; pMenu->m_vMenuData.iPosition = MIT_END;
::WinSendMsg((HWND)m_hMenu, MM_INSERTITEM, (MPARAM)&pMenu->m_vMenuData, (MPARAM)rTitle.c_str()); ::WinSendMsg((HWND)m_hMenu, MM_INSERTITEM, (MPARAM)&pMenu->m_vMenuData, (MPARAM)Title.c_str());
#if wxUSE_ACCEL #if wxUSE_ACCEL
if (pMenu->HasAccels()) if (pMenu->HasAccels())
{ {

View File

@@ -54,6 +54,44 @@
#define OWNER_DRAWN_ONLY( code ) #define OWNER_DRAWN_ONLY( code )
#endif // wxUSE_OWNER_DRAWN/!wxUSE_OWNER_DRAWN #endif // wxUSE_OWNER_DRAWN/!wxUSE_OWNER_DRAWN
// ----------------------------------------------------------------------------
// static function for translating menu labels
// ----------------------------------------------------------------------------
static wxString TextToLabel(const wxString& rTitle)
{
wxString Title;
const wxChar *pc;
for (pc = rTitle; *pc != wxT('\0'); pc++ )
{
if (*pc == wxT('&') )
{
if (*(pc+1) == wxT('&'))
{
pc++;
Title << wxT('&');
}
else
Title << wxT('~');
}
// else if (*pc == wxT('/'))
// {
// Title << wxT('\\');
// }
else
{
if ( *pc == wxT('~') )
{
// tildes must be doubled to prevent them from being
// interpreted as accelerator character prefix by PM ???
Title << *pc;
}
Title << *pc;
}
}
return Title;
}
// ============================================================================ // ============================================================================
// implementation // implementation
// ============================================================================ // ============================================================================
@@ -84,7 +122,7 @@ wxMenuItem::wxMenuItem(
, wxMenu* pSubMenu , wxMenu* pSubMenu
) )
#if wxUSE_OWNER_DRAWN #if wxUSE_OWNER_DRAWN
: wxOwnerDrawn( rText : wxOwnerDrawn( TextToLabel(rText)
,bCheckable ,bCheckable
) )
#endif // owner drawn #endif // owner drawn
@@ -114,7 +152,7 @@ wxMenuItem::wxMenuItem(
m_isEnabled = TRUE; m_isEnabled = TRUE;
m_isChecked = FALSE; m_isChecked = FALSE;
m_id = nId; m_id = nId;
m_text = rText; m_text = TextToLabel(rText);
m_isCheckable = bCheckable; m_isCheckable = bCheckable;
m_help = rStrHelp; m_help = rStrHelp;
} // end of wxMenuItem::wxMenuItem } // end of wxMenuItem::wxMenuItem
@@ -153,7 +191,19 @@ wxString wxMenuItemBase::GetLabelFromText(
const wxString& rText const wxString& rText
) )
{ {
return wxStripMenuCodes(rText); wxString label;
for ( const wxChar *pc = rText.c_str(); *pc; pc++ )
{
if ( *pc == wxT('~') || *pc == wxT('&') )
{
// '~' is the escape character for GTK+ and '&' is the one for
// wxWindows - skip both of them
continue;
}
label += *pc;
}
return label;
} }
// accelerators // accelerators
@@ -233,11 +283,13 @@ void wxMenuItem::SetText(
// //
// Don't do anything if label didn't change // Don't do anything if label didn't change
// //
if (m_text == rText)
wxString Text = TextToLabel(rText);
if (m_text == Text)
return; return;
wxMenuItemBase::SetText(rText); wxMenuItemBase::SetText(Text);
OWNER_DRAWN_ONLY(wxOwnerDrawn::SetName(rText)); OWNER_DRAWN_ONLY(wxOwnerDrawn::SetName(Text));
HWND hMenu = GetHMenuOf(m_parentMenu); HWND hMenu = GetHMenuOf(m_parentMenu);
@@ -279,7 +331,7 @@ void wxMenuItem::SetText(
#endif //owner drawn #endif //owner drawn
{ {
uFlagsOld |= MIS_TEXT; uFlagsOld |= MIS_TEXT;
pData = (BYTE*)rText.c_str(); pData = (BYTE*)Text.c_str();
} }
// //