#ifndef ROOT_TGWindow
#define ROOT_TGWindow
#ifndef ROOT_TGObject
#include "TGObject.h"
#endif
#ifndef ROOT_TGClient
#include "TGClient.h"
#endif
#ifndef ROOT_TVirtualX
#include "TVirtualX.h"
#endif
class TGClient;
class TGIdleHandler;
class TGWindow : public TGObject {
friend class TGClient;
protected:
const TGWindow *fParent;
Bool_t fNeedRedraw;
TString fName;
static Int_t fgCounter;
UInt_t fEditDisabled;
TGWindow(Window_t id) :
fParent(0), fNeedRedraw(kFALSE), fName(), fEditDisabled(0) { fClient = 0; fId = id; }
TGWindow(const TGWindow& tgw) :
TGObject(tgw), fParent(tgw.fParent), fNeedRedraw(tgw.fNeedRedraw),
fName(tgw.fName), fEditDisabled(tgw.fEditDisabled) { }
TGWindow& operator=(const TGWindow& tgw)
{ if (this!=&tgw) { TGObject::operator=(tgw); fParent=tgw.fParent;
fNeedRedraw=tgw.fNeedRedraw; fName=tgw.fName;
fEditDisabled=tgw.fEditDisabled; } return *this; }
virtual void DoRedraw() { }
public:
enum EEditMode {
kEditEnable = 0,
kEditDisable = BIT(0),
kEditDisableEvents = BIT(1),
kEditDisableGrab = BIT(2),
kEditDisableLayout = BIT(3),
kEditDisableResize = BIT(4),
kEditDisableHeight = BIT(5),
kEditDisableWidth = BIT(6),
kEditDisableBtnEnable = BIT(7),
kEditDisableKeyEnable = BIT(8)
};
TGWindow(const TGWindow *p = 0, Int_t x = 0, Int_t y = 0,
UInt_t w = 0, UInt_t h = 0, UInt_t border = 0,
Int_t depth = 0,
UInt_t clss = 0,
void *visual = 0,
SetWindowAttributes_t *attr = 0,
UInt_t wtype = 0);
TGWindow(TGClient *c, Window_t id, const TGWindow *parent = 0);
virtual ~TGWindow();
const TGWindow *GetParent() const { return fParent; }
virtual const TGWindow *GetMainFrame() const;
virtual void MapWindow() { gVirtualX->MapWindow(fId); }
virtual void MapSubwindows() { gVirtualX->MapSubwindows(fId); }
virtual void MapRaised() { gVirtualX->MapRaised(fId); }
virtual void UnmapWindow() { gVirtualX->UnmapWindow(fId); }
virtual void DestroyWindow() { gVirtualX->DestroyWindow(fId); }
virtual void DestroySubwindows() { gVirtualX->DestroySubwindows(fId); }
virtual void RaiseWindow() { gVirtualX->RaiseWindow(fId); }
virtual void LowerWindow() { gVirtualX->LowerWindow(fId); }
virtual void IconifyWindow() { gVirtualX->IconifyWindow(fId); }
virtual void ReparentWindow(const TGWindow *p, Int_t x = 0, Int_t y = 0);
virtual void RequestFocus() { gVirtualX->SetInputFocus(fId); }
virtual void SetBackgroundColor(Pixel_t color)
{ gVirtualX->SetWindowBackground(fId, color); }
virtual void SetBackgroundPixmap(Pixmap_t pixmap)
{ gVirtualX->SetWindowBackgroundPixmap(fId, pixmap); }
virtual Bool_t HandleExpose(Event_t *event)
{ if (event->fCount == 0) fClient->NeedRedraw(this); return kTRUE; }
virtual Bool_t HandleEvent(Event_t *) { return kFALSE; }
virtual Bool_t HandleTimer(TTimer *) { return kFALSE; }
virtual Bool_t HandleIdleEvent(TGIdleHandler *) { return kFALSE; }
virtual void Move(Int_t x, Int_t y);
virtual void Resize(UInt_t w, UInt_t h);
virtual void MoveResize(Int_t x, Int_t y, UInt_t w, UInt_t h);
virtual Bool_t IsMapped();
virtual Bool_t IsEditable() const { return (fClient->GetRoot() == this); }
virtual UInt_t GetEditDisabled() const { return fEditDisabled; }
virtual void SetEditDisabled(UInt_t on = kEditDisable) { fEditDisabled = on; }
virtual void SetEditable(Bool_t on = kTRUE)
{ if (!(fEditDisabled & kEditDisable)) fClient->SetRoot(on ? this : 0); }
virtual Int_t MustCleanup() const { return 0; }
virtual void Print(Option_t *option="") const;
virtual void SetWindowName(const char *name = 0);
virtual const char *GetName() const;
virtual void SetName(const char *name) { fName = name; }
virtual void SetMapSubwindows(Bool_t ) { }
virtual Bool_t IsMapSubwindows() const { return kTRUE; }
static Int_t GetCounter();
ClassDef(TGWindow,1)
};
class TGUnknownWindowHandler : public TObject {
public:
TGUnknownWindowHandler() { }
virtual ~TGUnknownWindowHandler() { }
virtual Bool_t HandleEvent(Event_t *) = 0;
ClassDef(TGUnknownWindowHandler,0)
};
#endif
Last change: Wed Jun 25 08:43:30 2008
Last generated: 2008-06-25 08:43
This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.