mark changes. Mac OSX taskbar implementation
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@29344 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -2192,10 +2192,12 @@ IMPORTANT: please read docs/tech/tn0016.txt before modifying this file!
|
|||||||
<set var="ADVANCED_MAC_SRC" hints="files">
|
<set var="ADVANCED_MAC_SRC" hints="files">
|
||||||
src/mac/carbon/joystick.cpp
|
src/mac/carbon/joystick.cpp
|
||||||
src/mac/carbon/sound.cpp
|
src/mac/carbon/sound.cpp
|
||||||
|
src/mac/carbon/taskbar.cpp
|
||||||
</set>
|
</set>
|
||||||
<set var="ADVANCED_MAC_HDR" hints="files">
|
<set var="ADVANCED_MAC_HDR" hints="files">
|
||||||
wx/mac/carbon/joystick.h
|
wx/mac/carbon/joystick.h
|
||||||
wx/mac/carbon/sound.h
|
wx/mac/carbon/sound.h
|
||||||
|
wx/mac/carbon/taskbarosx.h
|
||||||
</set>
|
</set>
|
||||||
|
|
||||||
<set var="ADVANCED_OS2_SRC" hints="files">
|
<set var="ADVANCED_OS2_SRC" hints="files">
|
||||||
|
@@ -215,8 +215,8 @@ All:
|
|||||||
All (GUI):
|
All (GUI):
|
||||||
|
|
||||||
- added wxWindow::MoveBefore/AfterInTabOrder() to change tab navigation order
|
- added wxWindow::MoveBefore/AfterInTabOrder() to change tab navigation order
|
||||||
- added wxTaskBarIcon::CreatePopupMenu which is now recommended way
|
- added wxTaskBarIcon::CreatePopupMenu which is now the recommended way
|
||||||
of showing popup menu; calling wxTaskBarIcon::PopupMenu directly
|
of showing a popup menu; calling wxTaskBarIcon::PopupMenu directly
|
||||||
is discouraged
|
is discouraged
|
||||||
- added ..._CMD_...(id) variants for wxGrid event table entry macros
|
- added ..._CMD_...(id) variants for wxGrid event table entry macros
|
||||||
- added wxWindow::Navigate for programmatic navigation to the next control
|
- added wxWindow::Navigate for programmatic navigation to the next control
|
||||||
@@ -245,6 +245,11 @@ Unix:
|
|||||||
builds of wxWidgets and to return flags/libs for selected libraries only
|
builds of wxWidgets and to return flags/libs for selected libraries only
|
||||||
- wx-config has new --version-full option
|
- wx-config has new --version-full option
|
||||||
|
|
||||||
|
wxMAC:
|
||||||
|
|
||||||
|
- Fixed MLTE text control GetLineText and GetLineLength on OSX (RN)
|
||||||
|
- Added OSX wxTaskBarIcon implementation for the OSX Dock (RN)
|
||||||
|
|
||||||
wxGTK:
|
wxGTK:
|
||||||
|
|
||||||
- wxGTK uses GTK+ 2.x by default now, you have to pass --disable-gtk2 to
|
- wxGTK uses GTK+ 2.x by default now, you have to pass --disable-gtk2 to
|
||||||
|
@@ -29,9 +29,9 @@
|
|||||||
#undef wxHAS_RAW_KEY_CODES
|
#undef wxHAS_RAW_KEY_CODES
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* taskbar is only implemented in wxMSW and X11 ports */
|
/* taskbar is only implemented in the major ports */
|
||||||
#if defined(__WXMSW__) || \
|
#if defined(__WXMSW__) || \
|
||||||
defined(__WXGTK__) || defined(__WXMOTIF__) || defined(__WXX11__)
|
defined(__WXGTK__) || defined(__WXMOTIF__) || defined(__WXX11__) || defined(__DARWIN__)
|
||||||
#define wxHAS_TASK_BAR_ICON
|
#define wxHAS_TASK_BAR_ICON
|
||||||
#else
|
#else
|
||||||
#undef wxHAS_TASK_BAR_ICON
|
#undef wxHAS_TASK_BAR_ICON
|
||||||
|
@@ -22,7 +22,8 @@ class WXDLLEXPORT wxMenu;
|
|||||||
class WXDLLEXPORT wxTaskBarIcon : public wxTaskBarIconBase
|
class WXDLLEXPORT wxTaskBarIcon : public wxTaskBarIconBase
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
//type of taskbar item to create (currently only DOCK is implemented)
|
//type of taskbar item to create
|
||||||
|
//TODO: currently only DOCK is implemented
|
||||||
enum wxTaskBarIconType
|
enum wxTaskBarIconType
|
||||||
{
|
{
|
||||||
DOCK,
|
DOCK,
|
||||||
@@ -33,16 +34,24 @@ public:
|
|||||||
wxTaskBarIcon(const wxTaskBarIconType& nType = DOCK);
|
wxTaskBarIcon(const wxTaskBarIconType& nType = DOCK);
|
||||||
virtual ~wxTaskBarIcon();
|
virtual ~wxTaskBarIcon();
|
||||||
|
|
||||||
// Operations:
|
//TODO: not tested extensively
|
||||||
bool SetIcon(const wxIcon& icon, const wxString& tooltip = wxEmptyString);
|
bool SetIcon(const wxIcon& icon, const wxString& tooltip = wxEmptyString);
|
||||||
bool RemoveIcon();
|
bool RemoveIcon();
|
||||||
|
//TODO: end not tested extensively
|
||||||
|
|
||||||
|
//pops up the menu
|
||||||
bool PopupMenu(wxMenu *menu);
|
bool PopupMenu(wxMenu *menu);
|
||||||
|
|
||||||
|
//internal functions - don't call
|
||||||
|
void SetInternalEvent(void* pEvent);
|
||||||
|
wxMenu* GetCurrentMenu();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
wxTaskBarIconType m_nType;
|
wxTaskBarIconType m_nType;
|
||||||
|
void* m_pEvent;
|
||||||
|
wxMenu* m_pMenu;
|
||||||
|
|
||||||
DECLARE_DYNAMIC_CLASS(wxTaskBarIcon)
|
DECLARE_DYNAMIC_CLASS(wxTaskBarIcon)
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
// _TASKBAR_H_
|
// _TASKBAR_H_
|
||||||
|
209
src/mac/carbon/taskbar.cpp
Normal file
209
src/mac/carbon/taskbar.cpp
Normal file
@@ -0,0 +1,209 @@
|
|||||||
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Name: taskbar.cpp
|
||||||
|
// Purpose: wxTaskBarIcon OSX Implementation
|
||||||
|
// Author: Ryan Norton
|
||||||
|
// Modified by:
|
||||||
|
// Created: 09/25/2004
|
||||||
|
// RCS-ID: $Id$
|
||||||
|
// Copyright: (c) 2004 Ryan Norton
|
||||||
|
// Licence: wxWindows licence
|
||||||
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
#include "wx/wxprec.h"
|
||||||
|
|
||||||
|
#include "wx/defs.h"
|
||||||
|
|
||||||
|
#ifdef wxHAS_TASK_BAR_ICON
|
||||||
|
|
||||||
|
#include "wx/mac/private.h"
|
||||||
|
|
||||||
|
#include "wx/taskbar.h"
|
||||||
|
#include "wx/menu.h"
|
||||||
|
#include "wx/icon.h"
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
|
||||||
|
#include "wx/frame.h"
|
||||||
|
#include "wx/dialog.h"
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
IMPLEMENT_DYNAMIC_CLASS(wxTaskBarIcon, wxEvtHandler)
|
||||||
|
|
||||||
|
pascal OSStatus wxDockEventHandler( EventHandlerCallRef inHandlerCallRef,
|
||||||
|
EventRef inEvent, void* pData)
|
||||||
|
{
|
||||||
|
wxTaskBarIcon*& pTB = (wxTaskBarIcon*&) pData;
|
||||||
|
|
||||||
|
const UInt32 eventClass = GetEventClass(inEvent);
|
||||||
|
const UInt32 eventKind = GetEventKind(inEvent);
|
||||||
|
|
||||||
|
if (eventClass == kEventClassCommand && eventKind == kEventCommandProcess)
|
||||||
|
{
|
||||||
|
MenuRef hMenu = MAC_WXHMENU(pTB->GetCurrentMenu()->GetHMenu());
|
||||||
|
OSStatus result = eventNotHandledErr ;
|
||||||
|
|
||||||
|
HICommand command ;
|
||||||
|
OSErr err;
|
||||||
|
|
||||||
|
err = GetEventParameter(inEvent, kEventParamDirectObject, typeHICommand,
|
||||||
|
NULL, sizeof(HICommand), NULL, &command);
|
||||||
|
wxASSERT(err == noErr);
|
||||||
|
|
||||||
|
MenuItemIndex menuItemIndex;
|
||||||
|
err = GetIndMenuItemWithCommandID(hMenu, command.commandID, 1, NULL, &menuItemIndex);
|
||||||
|
wxASSERT(err == noErr);
|
||||||
|
|
||||||
|
|
||||||
|
MenuCommand id = command.commandID ;
|
||||||
|
wxMenuItem* item = NULL;
|
||||||
|
// for items we don't really control
|
||||||
|
if ( id == kHICommandPreferences )
|
||||||
|
{
|
||||||
|
id = wxApp::s_macPreferencesMenuItemId ;
|
||||||
|
|
||||||
|
wxMenuBar* mbar = wxMenuBar::MacGetInstalledMenuBar() ;
|
||||||
|
if ( mbar )
|
||||||
|
{
|
||||||
|
wxMenu* menu = NULL ;
|
||||||
|
item = mbar->FindItem( id , &menu ) ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (id != 0)
|
||||||
|
GetMenuItemRefCon( hMenu , menuItemIndex , (UInt32*) &item ) ;
|
||||||
|
|
||||||
|
if ( item )
|
||||||
|
{
|
||||||
|
if (item->IsCheckable())
|
||||||
|
{
|
||||||
|
item->Check( !item->IsChecked() ) ;
|
||||||
|
}
|
||||||
|
|
||||||
|
item->GetMenu()->SendEvent( id , item->IsCheckable() ? item->IsChecked() : -1 ) ;
|
||||||
|
result = noErr ;
|
||||||
|
}
|
||||||
|
return result ;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxASSERT(eventClass == kEventClassApplication && eventKind == kEventAppGetDockTileMenu);
|
||||||
|
|
||||||
|
//set the internal event
|
||||||
|
pTB->SetInternalEvent(inEvent);
|
||||||
|
|
||||||
|
//process the right click event
|
||||||
|
wxTaskBarIconEvent evt(wxEVT_TASKBAR_RIGHT_UP,NULL);
|
||||||
|
pTB->ProcessEvent(evt);
|
||||||
|
|
||||||
|
//set the internal event
|
||||||
|
pTB->SetInternalEvent(NULL);
|
||||||
|
|
||||||
|
return noErr;
|
||||||
|
}
|
||||||
|
|
||||||
|
DEFINE_ONE_SHOT_HANDLER_GETTER( wxDockEventHandler );
|
||||||
|
|
||||||
|
wxTaskBarIcon::wxTaskBarIcon(const wxTaskBarIconType& nType)
|
||||||
|
: m_nType(nType), m_pEvent(NULL), m_pMenu(NULL)
|
||||||
|
{
|
||||||
|
//Register the events that will return the dock menu
|
||||||
|
EventTypeSpec tbEventList[] = { { kEventClassCommand, kEventProcessCommand },
|
||||||
|
{ kEventClassApplication, kEventAppGetDockTileMenu } };
|
||||||
|
|
||||||
|
OSStatus err = InstallApplicationEventHandler(
|
||||||
|
GetwxDockEventHandlerUPP(),
|
||||||
|
GetEventTypeCount(tbEventList), tbEventList,
|
||||||
|
this, NULL);
|
||||||
|
|
||||||
|
wxASSERT(err == noErr);
|
||||||
|
}
|
||||||
|
wxTaskBarIcon::~wxTaskBarIcon()
|
||||||
|
{
|
||||||
|
//TODO:uninstall event handler
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTaskBarIcon::SetInternalEvent(void* pEvent)
|
||||||
|
{
|
||||||
|
m_pEvent = pEvent;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxMenu* wxTaskBarIcon::GetCurrentMenu()
|
||||||
|
{
|
||||||
|
return m_pMenu;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Operations:
|
||||||
|
bool wxTaskBarIcon::SetIcon(const wxIcon& icon, const wxString& tooltip)
|
||||||
|
{
|
||||||
|
#if 0
|
||||||
|
wxASSERT(wxTheApp);
|
||||||
|
wxWindow* pTopWindow = wxTheApp->GetTopWindow();
|
||||||
|
|
||||||
|
wxASSERT(pTopWindow);
|
||||||
|
|
||||||
|
if(pTopWindow->IsKindOf(CLASSINFO(wxDialog)))
|
||||||
|
((wxDialog*)pTopWindow)->SetIcon(icon);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
wxASSERT(pTopWindow->IsKindOf(CLASSINFO(wxFrame)));
|
||||||
|
((wxFrame*)pTopWindow)->SetIcon(icon);
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
#else
|
||||||
|
//TODO: Educated guess
|
||||||
|
|
||||||
|
CGImageRef pImage;
|
||||||
|
//create the icon from the bitmap and mask bitmap contained within
|
||||||
|
OSStatus err = CreateCGImageFromPixMaps(
|
||||||
|
GetGWorldPixMap(MAC_WXHBITMAP(icon.GetHBITMAP())),
|
||||||
|
GetGWorldPixMap(MAC_WXHBITMAP(icon.GetMask()->GetMaskBitmap())),
|
||||||
|
&pImage
|
||||||
|
);
|
||||||
|
|
||||||
|
wxASSERT(err == 0);
|
||||||
|
|
||||||
|
err = SetApplicationDockTileImage(pImage);
|
||||||
|
|
||||||
|
wxASSERT(err == 0);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
bool wxTaskBarIcon::RemoveIcon()
|
||||||
|
{
|
||||||
|
//TODO: Not tested
|
||||||
|
OSStatus err = RestoreApplicationDockTileImage();
|
||||||
|
wxASSERT(err == 0);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool wxTaskBarIcon::PopupMenu(wxMenu *menu)
|
||||||
|
{
|
||||||
|
wxASSERT(m_pEvent != NULL);
|
||||||
|
|
||||||
|
if (m_pMenu)
|
||||||
|
delete m_pMenu;
|
||||||
|
|
||||||
|
m_pMenu = menu;
|
||||||
|
menu->SetEventHandler(this);
|
||||||
|
|
||||||
|
//note to self - a MenuRef IS A MenuHandle
|
||||||
|
MenuRef hMenu = MAC_WXHMENU(menu->GetHMenu());
|
||||||
|
|
||||||
|
//When we call SetEventParameter it will decrement
|
||||||
|
//the reference count of the menu - we need to make
|
||||||
|
//sure it stays around in the wxMenu class here
|
||||||
|
RetainMenu(hMenu);
|
||||||
|
|
||||||
|
//set the actual dock menu
|
||||||
|
OSStatus err = SetEventParameter((EventRef) m_pEvent, kEventParamMenuRef,
|
||||||
|
typeMenuRef, sizeof(MenuRef),
|
||||||
|
&hMenu);
|
||||||
|
wxASSERT(err == 0);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif //wxHAS_TASK_BAR_ICON
|
Reference in New Issue
Block a user