97 TAttLine::operator=(
b);
98 TAttFill::operator=(
b);
122 ((
TBox&)obj).fTip =
nullptr;
137 Int_t pxl, pyl, pxt, pyt;
146 if (
gPad->GetLogx()) {
150 if (
gPad->GetLogy()) {
156 if (px1 < px2) {pxl = px1; pxt = px2;}
157 else {pxl = px2; pxt = px1;}
158 if (py1 < py2) {pyl = py1; pyt = py2;}
159 else {pyl = py2; pyt = py1;}
163 if ( (px >= pxl && px <= pxt) && (py >= pyl && py <= pyt) )
return 0;
169 if (py < pyl) dxl += pyl - py;
170 if (py > pyt) dxl += py - pyt;
172 if (py < pyl) dxt += pyl - py;
173 if (py > pyt) dxt += py - pyt;
175 if (px < pxl) dyl += pxl - px;
176 if (px > pxt) dyl += px - pxt;
178 if (px < pxl) dyt += pxl - px;
179 if (px > pxt) dyt += px - pxt;
181 Int_t distance = dxl;
182 if (dxt < distance) distance = dxt;
183 if (dyl < distance) distance = dyl;
184 if (dyt < distance) distance = dyt;
240 const Int_t kMaxDiff = 7;
241 const Int_t kMinSize = 20;
243 static Int_t px1, px2, py1, py2, pxl, pyl, pxt, pyt, pxold, pyold;
244 static Int_t px1p, px2p, py1p, py2p, pxlp, pylp, pxtp, pytp;
245 static Double_t oldX1, oldY1, oldX2, oldY2;
246 static Bool_t pA, pB, pC, pD, pTop, pL, pR, pBot, pINSIDE;
289 if (
gPad->GetLogx()) {
293 if (
gPad->GetLogy()) {
334 pA = pB = pC = pD = pTop = pL = pR = pBot = pINSIDE =
kFALSE;
338 pxold = pxl; pyold = pyl; pA =
kTRUE;
343 pxold = pxt; pyold = pyl; pB =
kTRUE;
348 pxold = pxt; pyold = pyt; pC =
kTRUE;
353 pxold = pxl; pyold = pyt; pD =
kTRUE;
357 if ((px > pxl+kMaxDiff && px < pxt-kMaxDiff) &&
359 pxold = pxl; pyold = pyl; pTop =
kTRUE;
363 if ((px > pxl+kMaxDiff && px < pxt-kMaxDiff) &&
365 pxold = pxt; pyold = pyt; pBot =
kTRUE;
369 if ((py > pyl+kMaxDiff && py < pyt-kMaxDiff) &&
371 pxold = pxl; pyold = pyl; pL =
kTRUE;
375 if ((py > pyl+kMaxDiff && py < pyt-kMaxDiff) &&
377 pxold = pxt; pyold = pyt; pR =
kTRUE;
381 if ((px > pxl+kMaxDiff && px < pxt-kMaxDiff) &&
382 (py > pyl+kMaxDiff && py < pyt-kMaxDiff)) {
383 pxold = px; pyold = py; pINSIDE =
kTRUE;
391 if (pA || pB || pC || pD || pTop || pL || pR || pBot)
394 if (!pA && !pB && !pC && !pD && !pTop && !pL && !pR && !pBot && !pINSIDE)
406 if (px > pxt-kMinSize) { px = pxt-kMinSize; wx = px; }
407 if (py > pyt-kMinSize) { py = pyt-kMinSize; wy = py; }
408 if (px < pxlp) { px = pxlp; wx = px; }
409 if (py < pylp) { py = pylp; wy = py; }
414 if (px < pxl+kMinSize) { px = pxl+kMinSize; wx = px; }
415 if (py > pyt-kMinSize) { py = pyt-kMinSize; wy = py; }
416 if (px > pxtp) { px = pxtp; wx = px; }
417 if (py < pylp) { py = pylp; wy = py; }
422 if (px < pxl+kMinSize) { px = pxl+kMinSize; wx = px; }
423 if (py < pyl+kMinSize) { py = pyl+kMinSize; wy = py; }
424 if (px > pxtp) { px = pxtp; wx = px; }
425 if (py > pytp) { py = pytp; wy = py; }
430 if (px > pxt-kMinSize) { px = pxt-kMinSize; wx = px; }
431 if (py < pyl+kMinSize) { py = pyl+kMinSize; wy = py; }
432 if (px < pxlp) { px = pxlp; wx = px; }
433 if (py > pytp) { py = pytp; wy = py; }
439 if (py2 > py1-kMinSize) { py2 = py1-kMinSize; wy = py2; }
440 if (py2 < py2p) { py2 = py2p; wy = py2; }
446 if (py1 < py2+kMinSize) { py1 = py2+kMinSize; wy = py1; }
447 if (py1 > py1p) { py1 = py1p; wy = py1; }
453 if (px1 > px2-kMinSize) { px1 = px2-kMinSize; wx = px1; }
454 if (px1 < px1p) { px1 = px1p; wx = px1; }
460 if (px2 < px1+kMinSize) { px2 = px1+kMinSize; wx = px2; }
461 if (px2 > px2p) { px2 = px2p; wx = px2; }
466 Int_t dx = px - pxold;
467 Int_t dy = py - pyold;
468 px1 += dx; py1 += dy; px2 += dx; py2 += dy;
469 if (px1 < px1p) { dx = px1p - px1; px1 += dx; px2 += dx; wx = px+dx; }
470 if (px2 > px2p) { dx = px2 - px2p; px1 -= dx; px2 -= dx; wx = px-dx; }
471 if (py1 > py1p) { dy = py1 - py1p; py1 -= dy; py2 -= dy; wy = py-dy; }
472 if (py2 < py2p) { dy = py2p - py2; py1 += dy; py2 += dy; wy = py+dy; }
486 if ((pINSIDE && opaque) || (
fResizing && ropaque)) {
488 fX1 =
gPad->AbsPixeltoX(pxold);
491 fY2 =
gPad->AbsPixeltoY(pyold);
496 fX2 =
gPad->AbsPixeltoX(pxold);
497 fY2 =
gPad->AbsPixeltoY(pyold);
501 fY1 =
gPad->AbsPixeltoY(pyold);
502 fX2 =
gPad->AbsPixeltoX(pxold);
506 fX1 =
gPad->AbsPixeltoX(pxold);
507 fY1 =
gPad->AbsPixeltoY(pyold);
511 if (pTop || pBot || pL || pR || pINSIDE) {
519 if (
gPad->GetLogx()) {
523 if (
gPad->GetLogy()) {
529 if (pINSIDE)
gPad->ShowGuidelines(
this,
event,
'i',
true);
530 if (pTop)
gPad->ShowGuidelines(
this,
event,
't',
true);
531 if (pBot)
gPad->ShowGuidelines(
this,
event,
'b',
true);
532 if (pL)
gPad->ShowGuidelines(
this,
event,
'l',
true);
533 if (pR)
gPad->ShowGuidelines(
this,
event,
'r',
true);
534 if (pA)
gPad->ShowGuidelines(
this,
event,
'1',
true);
535 if (pB)
gPad->ShowGuidelines(
this,
event,
'2',
true);
536 if (pC)
gPad->ShowGuidelines(
this,
event,
'3',
true);
537 if (pD)
gPad->ShowGuidelines(
this,
event,
'4',
true);
544 if (
gROOT->IsEscaped()) {
557 if (opaque || ropaque) {
562 fX1 =
gPad->AbsPixeltoX(pxold);
565 fY2 =
gPad->AbsPixeltoY(pyold);
570 fX2 =
gPad->AbsPixeltoX(pxold);
571 fY2 =
gPad->AbsPixeltoY(pyold);
575 fY1 =
gPad->AbsPixeltoY(pyold);
576 fX2 =
gPad->AbsPixeltoX(pxold);
580 fX1 =
gPad->AbsPixeltoX(pxold);
581 fY1 =
gPad->AbsPixeltoY(pyold);
585 if (pTop || pBot || pL || pR || pINSIDE) {
593 if (
gPad->GetLogx()) {
597 if (
gPad->GetLogy()) {
609 if (pA || pB || pC || pD || pTop || pL || pR || pBot)
gPad->Modified(
kTRUE);
624 event =
gVirtualX->RequestLocator(1, 1, px, py);
652 if (x < fX1 || x >
fX2)
return 0;
653 if (y < fY1 || y >
fY2)
return 0;
716 out<<
"box = new TBox("<<
fX1<<
","<<
fY1<<
","<<
fX2<<
","<<
fY2<<
");"<<std::endl;
721 out<<
" box->Draw();"<<std::endl;
732 Warning(
"SetToolTipText",
"a canvas must exist before setting the tool tip text");
780 Int_t px1, py1, px2, py2;
787 if (px1>px2) { tmp = px1; px1 = px2; px2 = tmp;}
788 if (py1>py2) { tmp = py1; py1 = py2; py2 = tmp;}
804 if (!
gPad)
return (
p);
winID h TVirtualViewer3D TVirtualGLPainter p
Option_t Option_t TPoint TPoint const char x2
Option_t Option_t TPoint TPoint const char x1
Option_t Option_t TPoint TPoint const char y2
Option_t Option_t TPoint TPoint const char text
Option_t Option_t TPoint TPoint const char y1
Abstract base class for elements drawn in the editor.
Fill Area Attributes class.
virtual void Streamer(TBuffer &)
virtual Color_t GetFillColor() const
Return the fill area color.
void Copy(TAttFill &attfill) const
Copy this fill attributes to a new TAttFill.
virtual Style_t GetFillStyle() const
Return the fill area style.
virtual void Modify()
Change current fill area attributes if necessary.
virtual void SaveFillAttributes(std::ostream &out, const char *name, Int_t coldef=1, Int_t stydef=1001)
Save fill attributes as C++ statement(s) on output stream out.
virtual void Streamer(TBuffer &)
virtual Color_t GetLineColor() const
Return the line color.
virtual Width_t GetLineWidth() const
Return the line width.
Width_t fLineWidth
Line width.
virtual Style_t GetLineStyle() const
Return the line style.
virtual void Modify()
Change current line attributes if necessary.
void Copy(TAttLine &attline) const
Copy this line attributes to a new TAttLine.
virtual void SaveLineAttributes(std::ostream &out, const char *name, Int_t coldef=1, Int_t stydef=1, Int_t widdef=1)
Save line attributes as C++ statement(s) on output stream out.
void Draw(Option_t *option="") override
Draw this box with its current attributes.
virtual void SetToolTipText(const char *text, Long_t delayms=1000)
Set tool tip text associated with this box.
virtual void SetY2(Double_t y2)
virtual void PaintBox(Double_t x1, Double_t y1, Double_t x2, Double_t y2, Option_t *option="")
Draw this box with new coordinates.
void Streamer(TBuffer &) override
Stream an object of class TBox.
void SetBBoxX1(const Int_t x) override
Set left hand side of BoundingBox to a value (resize in x direction on left)
TBox & operator=(const TBox &)
Assignment operator.
void SetBBoxY2(const Int_t y) override
Set bottom of BoundingBox to a value (resize in y direction on bottom)
void SetBBoxY1(const Int_t y) override
Set top of BoundingBox to a value (resize in y direction on top)
Double_t fX1
X of 1st point.
TClass * IsA() const override
virtual void HideToolTip(Int_t event)
Hide tool tip depending on the event type.
void SetBBoxCenterY(const Int_t y) override
Set Y coordinate of the center of the Box.
void ls(Option_t *option="") const override
List this box with its attributes.
void ExecuteEvent(Int_t event, Int_t px, Int_t py) override
Execute action corresponding to one event.
virtual void SetX1(Double_t x1)
void Paint(Option_t *option="") override
Paint this box with its current attributes.
virtual Int_t IsInside(Double_t x, Double_t y) const
Function which returns 1 if point x,y lies inside the box, 0 otherwise.
TPoint GetBBoxCenter() override
Return the center of the Box as TPoint in pixels.
virtual void SetX2(Double_t x2)
virtual ~TBox()
Box destructor.
TBox()
Box default constructor.
virtual TBox * DrawBox(Double_t x1, Double_t y1, Double_t x2, Double_t y2)
Draw this box with new coordinates.
Rectangle_t GetBBox() override
Return the "bounding Box" of the Box.
void Print(Option_t *option="") const override
Dump this box with its attributes.
TObject * fTip
! tool tip associated with box
void SetBBoxCenter(const TPoint &p) override
Set center of the Box.
Double_t fY2
Y of 2nd point.
void SavePrimitive(std::ostream &out, Option_t *option="") override
Save primitive as a C++ statement(s) on output stream out.
Double_t fX2
X of 2nd point.
Double_t fY1
Y of 1st point.
void Copy(TObject &box) const override
Copy a Box.
Int_t DistancetoPrimitive(Int_t px, Int_t py) override
Compute distance from point px,py to a box.
Bool_t fResizing
! True if box is being resized
void SetBBoxX2(const Int_t x) override
Set right hand side of BoundingBox to a value (resize in x direction on right)
virtual void SetY1(Double_t y1)
void SetBBoxCenterX(const Int_t x) override
Set X coordinate of the center of the Box.
Buffer base class used for serializing objects.
virtual Version_t ReadVersion(UInt_t *start=nullptr, UInt_t *bcnt=nullptr, const TClass *cl=nullptr)=0
virtual Int_t CheckByteCount(UInt_t startpos, UInt_t bcnt, const TClass *clss)=0
virtual Int_t ReadClassBuffer(const TClass *cl, void *pointer, const TClass *onfile_class=nullptr)=0
virtual Int_t WriteClassBuffer(const TClass *cl, void *pointer)=0
Mother of all ROOT objects.
virtual const char * GetName() const
Returns name of object.
TObject & operator=(const TObject &rhs)
TObject assignment operator.
R__ALWAYS_INLINE Bool_t TestBit(UInt_t f) const
virtual void Streamer(TBuffer &)
Stream an object of class TObject.
virtual void Warning(const char *method, const char *msgfmt,...) const
Issue warning message.
virtual void AppendPad(Option_t *option="")
Append graphics object to current pad.
void SetBit(UInt_t f, Bool_t set)
Set or unset the user status bits as specified in f.
virtual Bool_t InheritsFrom(const char *classname) const
Returns kTRUE if object inherits from class "classname".
virtual void Copy(TObject &object) const
Copy this to obj.
@ kCanDelete
if object in a list can be deleted
static void IndentLevel()
Functions used by ls() to indent an object hierarchy.
void ToLower()
Change string to lower-case.
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
TVirtualPad is an abstract base class for the Pad and Canvas classes.
virtual Int_t YtoAbsPixel(Double_t y) const =0
virtual Double_t GetX2() const =0
virtual Int_t XtoAbsPixel(Double_t x) const =0
virtual Double_t GetY1() const =0
virtual Double_t GetY2() const =0
virtual Short_t GetBorderSize() const =0
virtual Double_t GetX1() const =0
void box(Int_t pat, Double_t x1, Double_t y1, Double_t x2, Double_t y2)
Short_t Max(Short_t a, Short_t b)
Returns the largest of a and b.
LongDouble_t Power(LongDouble_t x, LongDouble_t y)
Returns x raised to the power y.
Short_t Min(Short_t a, Short_t b)
Returns the smallest of a and b.
Double_t Log10(Double_t x)
Returns the common (base-10) logarithm of x.
Short_t Abs(Short_t d)
Returns the absolute value of parameter Short_t d.
Rectangle structure (maps to the X11 XRectangle structure)