Added wxPopupWindow skeleton (no implementation yet)

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@14116 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Julian Smart
2002-02-10 23:21:44 +00:00
parent bafb8cdde4
commit 1246e28fb0
3 changed files with 107 additions and 33 deletions

View File

@@ -623,6 +623,7 @@ main.cpp X11
minifram.cpp X11 minifram.cpp X11
palette.cpp X11 palette.cpp X11
pen.cpp X11 pen.cpp X11
popupwin.cpp X11
region.cpp X11 region.cpp X11
settings.cpp X11 settings.cpp X11
toplevel.cpp X11 toplevel.cpp X11

View File

@@ -1,50 +1,52 @@
/////////////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////////
// Name: wx/msw/popupwin.h // Name: popupwin.h
// Purpose: wxPopupWindow class for wxMSW // Purpose:
// Author: Vadim Zeitlin // Author: Robert Roebling
// Modified by: // Created:
// Created: 06.01.01 // Id: $Id$
// RCS-ID: $Id$ // Copyright: (c) 2001 Robert Roebling
// Copyright: (c) 2001 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
// Licence: wxWindows licence // Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////////
#ifndef _WX_MSW_POPUPWIN_H_ #ifndef __GTKPOPUPWINH__
#define _WX_MSW_POPUPWIN_H_ #define __GTKPOPUPWINH__
// ---------------------------------------------------------------------------- #ifdef __GNUG__
// wxPopupWindow #pragma interface "popupwin.h"
// ---------------------------------------------------------------------------- #endif
class WXDLLEXPORT wxPopupWindow : public wxPopupWindowBase #include "wx/defs.h"
#include "wx/panel.h"
#include "wx/icon.h"
//-----------------------------------------------------------------------------
// wxPopUpWindow
//-----------------------------------------------------------------------------
class wxPopupWindow: public wxPopupWindowBase
{ {
public: public:
wxPopupWindow() { } wxPopupWindow() { }
virtual ~wxPopupWindow() { }
wxPopupWindow(wxWindow *parent, int flags = wxBORDER_NONE) wxPopupWindow(wxWindow *parent, int flags = wxBORDER_NONE)
{ (void)Create(parent, flags); } { (void)Create(parent, flags); }
bool Create(wxWindow *parent, int flags = wxBORDER_NONE);
bool Create(wxWindow *parent, int flags = wxBORDER_NONE) virtual bool Show( bool show = TRUE );
{
return wxPopupWindowBase::Create(parent) && // implementation
wxWindow::Create(parent, -1, // --------------
wxDefaultPosition, wxDefaultSize,
(flags & wxBORDER_MASK) | wxPOPUP_WINDOW);
}
protected: protected:
virtual void DoGetPosition(int *x, int *y) const virtual void DoMoveWindow(int x, int y, int width, int height);
{ virtual void DoSetSize(int x, int y,
// the position of a "top level" window such as this should be in int width, int height,
// screen coordinates, not in the client ones which MSW gives us int sizeFlags = wxSIZE_AUTO);
// (because we are a child window)
wxPopupWindowBase::DoGetPosition(x, y);
GetParent()->ClientToScreen(x, y);
}
private:
DECLARE_EVENT_TABLE()
DECLARE_DYNAMIC_CLASS(wxPopupWindow) DECLARE_DYNAMIC_CLASS(wxPopupWindow)
}; };
#endif // _WX_MSW_POPUPWIN_H_ #endif // __GTKPOPUPWINDOWH__

71
src/x11/popupwin.cpp Normal file
View File

@@ -0,0 +1,71 @@
/////////////////////////////////////////////////////////////////////////////
// Name: popupwin.cpp
// Purpose:
// Author: Robert Roebling
// Id: $Id$
// Copyright: (c) 1998 Robert Roebling
// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
#ifdef __GNUG__
#pragma implementation "popupwin.h"
#endif
#include "wx/defs.h"
#if wxUSE_POPUPWIN
#include "wx/popupwin.h"
#include "wx/frame.h"
#include "wx/app.h"
#include "wx/cursor.h"
#include "wx/x11/private.h"
//-----------------------------------------------------------------------------
// wxPopupWindow
//-----------------------------------------------------------------------------
BEGIN_EVENT_TABLE(wxPopupWindow,wxPopupWindowBase)
END_EVENT_TABLE()
IMPLEMENT_DYNAMIC_CLASS(wxPopupWindow, wxWindow)
bool wxPopupWindow::Create( wxWindow *parent, int style )
{
m_needParent = FALSE;
if (!CreateBase( parent, -1, wxDefaultPosition, wxDefaultSize, style, wxDefaultValidator, "popup" ))
{
wxFAIL_MSG( wxT("wxPopupWindow creation failed") );
return FALSE;
}
// All dialogs should really have this style
m_windowStyle |= wxTAB_TRAVERSAL;
if (m_parent) m_parent->AddChild( this );
// TODO: implementation
return TRUE;
}
void wxPopupWindow::DoMoveWindow(int WXUNUSED(x), int WXUNUSED(y), int WXUNUSED(width), int WXUNUSED(height) )
{
wxFAIL_MSG( wxT("DoMoveWindow called for wxPopupWindow") );
}
void wxPopupWindow::DoSetSize( int x, int y, int width, int height, int sizeFlags )
{
// TODO
}
bool wxPopupWindow::Show( bool show )
{
// TODO?
bool ret = wxWindow::Show( show );
return ret;
}
#endif // wxUSE_POPUPWIN