git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@36513
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
int wxNotebook::HitTest(const wxPoint& pt, long * flags) const
{
int wxNotebook::HitTest(const wxPoint& pt, long * flags) const
{
- int resultV = wxNOT_FOUND;
+ int resultV = wxNOT_FOUND;
- const int countPages = GetPageCount();
-
+ const int countPages = GetPageCount();
+
HIPoint hipoint= { pt.x , pt.y } ;
HIViewPartCode outPart = 0 ;
OSStatus err = HIViewGetPartHit (
HIPoint hipoint= { pt.x , pt.y } ;
HIViewPartCode outPart = 0 ;
OSStatus err = HIViewGetPartHit (
int max = m_peer->GetMaximum() ;
if ( outPart == 0 && max > 0 )
{
// this is a hack, as unfortunately a hit on an already selected tab returns 0,
int max = m_peer->GetMaximum() ;
if ( outPart == 0 && max > 0 )
{
// this is a hack, as unfortunately a hit on an already selected tab returns 0,
- // so we have to go some extra miles to make sure we select something different
+ // so we have to go some extra miles to make sure we select something different
// and try again ..
int val = m_peer->GetValue() ;
int maxval = max ;
// and try again ..
int val = m_peer->GetValue() ;
int maxval = max ;
m_peer->SetValue( maxval ) ;
else
m_peer->SetValue( 1 ) ;
m_peer->SetValue( maxval ) ;
else
m_peer->SetValue( 1 ) ;
- m_peer->GetControlRef() ,
- &hipoint ,
- &outPart
- );
-
+ m_peer->GetControlRef() ,
+ &hipoint ,
+ &outPart
+ );
+
m_peer->SetValue( val ) ;
if ( max == 1 )
{
m_peer->SetMaximum( 1 ) ;
}
}
m_peer->SetValue( val ) ;
if ( max == 1 )
{
m_peer->SetMaximum( 1 ) ;
}
}
-
- if ( outPart >= 1 && (size_t)outPart <= countPages )
+
+ if ( outPart >= 1 && outPart <= countPages )
#endif // TARGET_API_MAC_OSX
if (flags != NULL)
{
*flags = 0;
#endif // TARGET_API_MAC_OSX
if (flags != NULL)
{
*flags = 0;
// we cannot differentiate better
if (resultV >= 1)
*flags |= wxNB_HITTEST_ONLABEL;
// we cannot differentiate better
if (resultV >= 1)
*flags |= wxNB_HITTEST_ONLABEL;
// Superclass of wxTaskBarIcon implementations
//-----------------------------------------------------------------------------
// Superclass of wxTaskBarIcon implementations
//-----------------------------------------------------------------------------
{
public:
wxTaskBarIconImpl(wxTaskBarIcon* parent);
{
public:
wxTaskBarIconImpl(wxTaskBarIcon* parent);
class wxTaskBarIconWindow : public wxTopLevelWindow
{
public:
class wxTaskBarIconWindow : public wxTopLevelWindow
{
public:
- wxTaskBarIconWindow(wxTaskBarIconImpl* impl)
- : wxTopLevelWindow(NULL, -1, wxT("")), m_impl(impl)
+ wxTaskBarIconWindow(wxTaskBarIconImpl* impl)
+ : wxTopLevelWindow(NULL, -1, wxT("")), m_impl(impl)
- Connect(-1, wxEVT_COMMAND_MENU_SELECTED,
+ Connect(-1, wxEVT_COMMAND_MENU_SELECTED,
wxCommandEventHandler(wxTaskBarIconWindow::OnMenuEvent)
);
}
wxCommandEventHandler(wxTaskBarIconWindow::OnMenuEvent)
);
}
- void OnMenuEvent(wxCommandEvent& event)
+ void OnMenuEvent(wxCommandEvent& event)
{
m_impl->m_parent->ProcessEvent(event);
}
{
m_impl->m_parent->ProcessEvent(event);
}
pascal OSStatus wxDockEventHandler( EventHandlerCallRef inHandlerCallRef,
EventRef inEvent, void* pData);
wxMenu* wxDeepCopyMenu(wxMenu* menu);
pascal OSStatus wxDockEventHandler( EventHandlerCallRef inHandlerCallRef,
EventRef inEvent, void* pData);
wxMenu* wxDeepCopyMenu(wxMenu* menu);
//=============================================================================
//
//=============================================================================
//
//
// Initializes members and creates the event window
//-----------------------------------------------------------------------------
//
// Initializes members and creates the event window
//-----------------------------------------------------------------------------
-wxTaskBarIconImpl::wxTaskBarIconImpl(wxTaskBarIcon* parent)
+wxTaskBarIconImpl::wxTaskBarIconImpl(wxTaskBarIcon* parent)
: m_parent(parent), m_menuEventWindow(new wxTaskBarIconWindow(this))
{
}
: m_parent(parent), m_menuEventWindow(new wxTaskBarIconWindow(this))
{
}
// This is the real reason why we need this. Normally menus
// get handled in wxMacAppEventHandler
//
// This is the real reason why we need this. Normally menus
// get handled in wxMacAppEventHandler
//
- // pascal OSStatus wxMacAppEventHandler(EventHandlerCallRef handler,
+ // pascal OSStatus wxMacAppEventHandler(EventHandlerCallRef handler,
// EventRef event, void *data)
//
// EventRef event, void *data)
//
- // However, in the case of a taskbar menu call
+ // However, in the case of a taskbar menu call
// command.menu.menuRef IS NULL!
// Which causes the wxApp handler just to skip it.
//
MenuRef taskbarMenuRef = MAC_WXHMENU(pTB->m_pMenu->GetHMenu());
// command.menu.menuRef IS NULL!
// Which causes the wxApp handler just to skip it.
//
MenuRef taskbarMenuRef = MAC_WXHMENU(pTB->m_pMenu->GetHMenu());
- OSStatus result = eventNotHandledErr;
OSErr err;
// get the HICommand from the event
HICommand command;
err = GetEventParameter(inEvent, kEventParamDirectObject,
OSErr err;
// get the HICommand from the event
HICommand command;
err = GetEventParameter(inEvent, kEventParamDirectObject,
sizeof(HICommand), NULL, &command);
if (err == noErr)
sizeof(HICommand), NULL, &command);
if (err == noErr)
// Obtain the REAL menuRef and the menuItemIndex in the real menuRef
//
// Obtain the REAL menuRef and the menuItemIndex in the real menuRef
//
- // NOTE: menuRef is generally used here for submenus, as
- // GetMenuItemRefCon could give an incorrect wxMenuItem if we pass
+ // NOTE: menuRef is generally used here for submenus, as
+ // GetMenuItemRefCon could give an incorrect wxMenuItem if we pass
// just the top level wxTaskBar menu
//
MenuItemIndex menuItemIndex;
MenuRef menuRef;
// just the top level wxTaskBar menu
//
MenuItemIndex menuItemIndex;
MenuRef menuRef;
- err = GetIndMenuItemWithCommandID(taskbarMenuRef,
- command.commandID,
+ err = GetIndMenuItemWithCommandID(taskbarMenuRef,
+ command.commandID,
1, &menuRef, &menuItemIndex);
if (err == noErr)
{
1, &menuRef, &menuItemIndex);
if (err == noErr)
{
item->Check( !item->IsChecked() ) ;
// send the wxEvent to the wxMenu
item->Check( !item->IsChecked() ) ;
// send the wxEvent to the wxMenu
- item->GetMenu()->SendEvent(id,
- item->IsCheckable() ?
- item->IsChecked() : -1
+ item->GetMenu()->SendEvent(id,
+ item->IsCheckable() ?
+ item->IsChecked() : -1
);
err = noErr; // successfully handled the event
}
}
);
err = noErr; // successfully handled the event
}
}
- } //end if noErr on getting HICommand from event
+ } //end if noErr on getting HICommand from event
// return whether we handled the event or not
return err;
}
// We better have a kEventClassApplication/kEventAppGetDockTileMenu combo here,
// return whether we handled the event or not
return err;
}
// We better have a kEventClassApplication/kEventAppGetDockTileMenu combo here,
- // otherwise something is truly funky
- wxASSERT(eventClass == kEventClassApplication &&
+ // otherwise something is truly funky
+ wxASSERT(eventClass == kEventClassApplication &&
eventKind == kEventAppGetDockTileMenu);
// process the right click events
eventKind == kEventAppGetDockTileMenu);
// process the right click events
RetainMenu(hMenu);
// set the actual dock menu
RetainMenu(hMenu);
// set the actual dock menu
- err = SetEventParameter(inEvent, kEventParamMenuRef,
+ err = SetEventParameter(inEvent, kEventParamMenuRef,
typeMenuRef, sizeof(MenuRef), &hMenu);
wxASSERT(err == noErr);
}
typeMenuRef, sizeof(MenuRef), &hMenu);
wxASSERT(err == noErr);
}
//
// NB: Here we have to perform a deep copy of the menu,
// copying each and every menu item from menu to m_pMenu.
//
// NB: Here we have to perform a deep copy of the menu,
// copying each and every menu item from menu to m_pMenu.
- // Other implementations use wxWindow::PopupMenu here,
+ // Other implementations use wxWindow::PopupMenu here,
// which idle execution until the user selects something,
// which idle execution until the user selects something,
- // but since the mac handles this internally, we can't -
+ // but since the mac handles this internally, we can't -
// and have no way at all to idle it while the dock menu
// is being shown before menu goes out of scope (it may
// not be on the heap, and may expire right after this function
// and have no way at all to idle it while the dock menu
// is being shown before menu goes out of scope (it may
// not be on the heap, and may expire right after this function
- // is done - we need it to last until the carbon event is triggered -
+ // is done - we need it to last until the carbon event is triggered -
// that's when the user right clicks).
//
// that's when the user right clicks).
//
- // Also, since there is no equal (assignment) operator
+ // Also, since there is no equal (assignment) operator
// on either wxMenu or wxMenuItem, we have to do all the
// dirty work ourselves.
//
// on either wxMenu or wxMenuItem, we have to do all the
// dirty work ourselves.
//
//
// Here we create some mac-specific event handlers and UPPs.
//-----------------------------------------------------------------------------
//
// Here we create some mac-specific event handlers and UPPs.
//-----------------------------------------------------------------------------
-wxDockTaskBarIcon::wxDockTaskBarIcon(wxTaskBarIcon* parent)
+wxDockTaskBarIcon::wxDockTaskBarIcon(wxTaskBarIcon* parent)
: wxTaskBarIconImpl(parent),
: wxTaskBarIconImpl(parent),
- m_eventHandlerRef(NULL), m_pMenu(NULL),
- m_theLastMenu(GetApplicationDockTileMenu()), m_iconAdded(false)
+ m_eventHandlerRef(NULL), m_pMenu(NULL),
+ m_theLastMenu(GetApplicationDockTileMenu()), m_iconAdded(false)
{
// register the events that will return the dock menu
EventTypeSpec tbEventList[] =
{
// register the events that will return the dock menu
EventTypeSpec tbEventList[] =
#endif
InstallApplicationEventHandler(
m_eventupp,
#endif
InstallApplicationEventHandler(
m_eventupp,
- GetEventTypeCount(tbEventList), tbEventList,
+ GetEventTypeCount(tbEventList), tbEventList,
this, &m_eventHandlerRef);
wxASSERT( err == noErr );
}
this, &m_eventHandlerRef);
wxASSERT( err == noErr );
}
DisposeEventHandlerUPP(m_eventupp);
// restore old icon and menu to the dock
DisposeEventHandlerUPP(m_eventupp);
// restore old icon and menu to the dock
}
//-----------------------------------------------------------------------------
// wxDockTaskBarIcon::DoCreatePopupMenu
//
}
//-----------------------------------------------------------------------------
// wxDockTaskBarIcon::DoCreatePopupMenu
//
-// Helper function that handles a request from the dock event handler
+// Helper function that handles a request from the dock event handler
// to get the menu for the dock
//-----------------------------------------------------------------------------
wxMenu* wxDockTaskBarIcon::DoCreatePopupMenu()
// to get the menu for the dock
//-----------------------------------------------------------------------------
wxMenu* wxDockTaskBarIcon::DoCreatePopupMenu()
m_pMenu->SetInvokingWindow(m_menuEventWindow);
}
m_pMenu->SetInvokingWindow(m_menuEventWindow);
}
- // the return here can be one of three things
+ // the return here can be one of three things
// (in order of priority):
// 1) User passed a menu from CreatePopupMenu override
// 2) menu sent to and copied from PopupMenu
// (in order of priority):
// 1) User passed a menu from CreatePopupMenu override
// 2) menu sent to and copied from PopupMenu
// Returns whether or not the dock is not using the default image
//-----------------------------------------------------------------------------
bool wxDockTaskBarIcon::IsIconInstalled() const
// Returns whether or not the dock is not using the default image
//-----------------------------------------------------------------------------
bool wxDockTaskBarIcon::IsIconInstalled() const
}
//-----------------------------------------------------------------------------
}
//-----------------------------------------------------------------------------
// get the CGImageRef for the wxBitmap:
// OSX builds only, but then the dock only exists in OSX
// get the CGImageRef for the wxBitmap:
// OSX builds only, but then the dock only exists in OSX
- CGImageRef pImage = (CGImageRef) bmp.CGImageCreate();
+ CGImageRef pImage = (CGImageRef) bmp.CGImageCreate();
wxASSERT( pImage != NULL );
// actually set the dock image
wxASSERT( pImage != NULL );
// actually set the dock image
//
// 2.4 and wxPython method that "pops of the menu in the taskbar".
//
//
// 2.4 and wxPython method that "pops of the menu in the taskbar".
//
-// In reality because of the way the dock menu works in carbon
+// In reality because of the way the dock menu works in carbon
// we just save the menu, and if the user didn't override CreatePopupMenu
// return the menu passed here, thus sort of getting the same effect.
//-----------------------------------------------------------------------------
// we just save the menu, and if the user didn't override CreatePopupMenu
// return the menu passed here, thus sort of getting the same effect.
//-----------------------------------------------------------------------------
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//
// wxTaskBarIcon
//
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//
// wxTaskBarIcon
//
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
IMPLEMENT_DYNAMIC_CLASS(wxTaskBarIcon, wxEvtHandler)
IMPLEMENT_DYNAMIC_CLASS(wxTaskBarIcon, wxEvtHandler)
//-----------------------------------------------------------------------------
// wxTaskBarIcon Constructor
//
//-----------------------------------------------------------------------------
// wxTaskBarIcon Constructor
//
//
// Note that we only support DOCK currently as others require cocoa and
// also some require hacks and other such things. (MenuExtras are
//
// Note that we only support DOCK currently as others require cocoa and
// also some require hacks and other such things. (MenuExtras are
-// actually seperate programs that also require a special undocumented id
+// actually seperate programs that also require a special undocumented id
// hack and other such fun stuff).
//-----------------------------------------------------------------------------
wxTaskBarIcon::wxTaskBarIcon(wxTaskBarIconType nType)
{
// hack and other such fun stuff).
//-----------------------------------------------------------------------------
wxTaskBarIcon::wxTaskBarIcon(wxTaskBarIconType nType)
{
- wxASSERT_MSG(nType == DOCK,
+ wxASSERT_MSG(nType == DOCK,
wxT("Only the DOCK implementation of wxTaskBarIcon")
wxT("on mac carbon is currently supported!"));
m_impl = new wxDockTaskBarIcon(this);
wxT("Only the DOCK implementation of wxTaskBarIcon")
wxT("on mac carbon is currently supported!"));
m_impl = new wxDockTaskBarIcon(this);
//wxChildFocusEvent eventFocus(this);
//(void)GetEventHandler()->ProcessEvent(eventFocus);
//wxChildFocusEvent eventFocus(this);
//(void)GetEventHandler()->ProcessEvent(eventFocus);
+#if !wxMAC_USE_CORE_GRAPHICS
bool bIsFocusEvent = (event.GetEventType() == wxEVT_SET_FOCUS);
bool bIsFocusEvent = (event.GetEventType() == wxEVT_SET_FOCUS);
// enable for patch 1376506 - perhaps?
#if 0
// enable for patch 1376506 - perhaps?
#if 0
void wxWindowMac::OnMouseEvent( wxMouseEvent &event )
{
void wxWindowMac::OnMouseEvent( wxMouseEvent &event )
{
- long evtType = event.GetEventType();
-// if ((evtType == ewxEVT_RIGHT_DOWN) || (evtType == wxEVT_CONTEXT_MENU))
if ( event.GetEventType() == wxEVT_RIGHT_DOWN )
{
// copied from wxGTK : CS
if ( event.GetEventType() == wxEVT_RIGHT_DOWN )
{
// copied from wxGTK : CS
+ // VZ: shouldn't we move this to base class then?
+
// generate a "context menu" event: this is similar to wxEVT_RIGHT_DOWN
// except that:
//
// generate a "context menu" event: this is similar to wxEVT_RIGHT_DOWN
// except that:
//