Logo ROOT   6.18/05
Reference Guide
TGListBox.cxx
Go to the documentation of this file.
1// @(#)root/gui:$Id$
2// Author: Fons Rademakers 12/01/98
3
4/*************************************************************************
5 * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers. *
6 * All rights reserved. *
7 * *
8 * For the licensing terms see $ROOTSYS/LICENSE. *
9 * For the list of contributors see $ROOTSYS/README/CREDITS. *
10 *************************************************************************/
11/**************************************************************************
12
13 This source is based on Xclass95, a Win95-looking GUI toolkit.
14 Copyright (C) 1996, 1997 David Barth, Ricky Ralston, Hector Peraza.
15
16 Xclass95 is free software; you can redistribute it and/or
17 modify it under the terms of the GNU Library General Public
18 License as published by the Free Software Foundation; either
19 version 2 of the License, or (at your option) any later version.
20
21**************************************************************************/
22
23//////////////////////////////////////////////////////////////////////////
24// //
25// TGListBox, TGLBContainer, TGLBEntry and TGTextLBEntry //
26// //
27// A listbox is a box, possibly with scrollbar, containing entries. //
28// Currently entries are simple text strings (TGTextLBEntry). //
29// A TGListBox looks a lot like a TGCanvas. It has a TGViewPort //
30// containing a TGLBContainer which contains the entries and it also //
31// has a vertical scrollbar which becomes visible if there are more //
32// items than fit in the visible part of the container. //
33// //
34// The TGListBox is user callable. The other classes are service //
35// classes of the listbox. //
36// //
37// Selecting an item in the listbox will generate the event: //
38// kC_COMMAND, kCM_LISTBOX, listbox id, item id. //
39// //
40//////////////////////////////////////////////////////////////////////////
41
42#include "TGPicture.h"
43#include "TGListBox.h"
44#include "TGScrollBar.h"
45#include "TGResourcePool.h"
46#include "TSystem.h"
47#include "Riostream.h"
48#include "TMath.h"
49#include <stdlib.h>
50
51
54
60
61////////////////////////////////////////////////////////////////////////////////
62/// Base class entry constructor.
63
64TGLBEntry::TGLBEntry(const TGWindow *p, Int_t id, UInt_t options, Pixel_t back) :
65 TGFrame(p, 10, 10, options | kOwnBackground, back)
66{
68 fEntryId = id;
69 fBkcolor = back;
71
73}
74
75////////////////////////////////////////////////////////////////////////////////
76/// Toggle active state of listbox entry.
77
79{
80 if (fActive == a) return;
81 fActive = a;
82 DoRedraw();
83}
84
85////////////////////////////////////////////////////////////////////////////////
86/// Toggle active state of listbox entry.
87
89{
91 DoRedraw();
92}
93
94
95//////////////////////////////////////////////////////////////////////////
96// //
97// TGTextLBEntry //
98// //
99// Text string listbox entries. //
100// A TGTextLBEntry is for TGListBox internal use. //
101// //
102//////////////////////////////////////////////////////////////////////////
103
104////////////////////////////////////////////////////////////////////////////////
105/// Create a text listbox entry. The TGString is adopted.
106
108 GContext_t norm, FontStruct_t font, UInt_t options, ULong_t back) :
109 TGLBEntry(p, id, options, back)
110{
111 fText = s;
113 fFontStruct = font;
114 fNormGC = norm;
115 fTWidth = 0;
116
117 int max_ascent, max_descent;
118
119 if (fText) fTWidth = gVirtualX->TextWidth(fFontStruct, fText->GetString(), fText->GetLength());
120 gVirtualX->GetFontProperties(fFontStruct, max_ascent, max_descent);
121 fTHeight = max_ascent + max_descent;
122 Resize(fTWidth, fTHeight + 1);
125}
126
127////////////////////////////////////////////////////////////////////////////////
128/// Delete text listbox entry.
129
131{
132 if (fText) delete fText;
133}
134
135////////////////////////////////////////////////////////////////////////////////
136/// Draw text listbox entry on window/pixmap.
137
139{
140 int max_ascent, max_descent;
141
142 y += (fHeight - fTHeight) >> 1;
143
144 gVirtualX->GetFontProperties(fFontStruct, max_ascent, max_descent);
145
146 if (fActive) {
148 gVirtualX->FillRectangle(id,fNormGC, x, y, fWidth, fHeight);
150 fText->Draw(id, fNormGC, x + 3, y + max_ascent);
151 } else {
152 gVirtualX->SetForeground(fNormGC, fBkcolor);
153 gVirtualX->FillRectangle(id, fNormGC, x, y, fWidth, fHeight);
154 gVirtualX->SetForeground(fNormGC, GetForeground());
155 fText->Draw(id, fNormGC, x + 3, y + max_ascent);
156 }
157}
158
159////////////////////////////////////////////////////////////////////////////////
160/// Redraw text listbox entry.
161
163{
164 if (fId) DrawCopy(fId, 0, 0);
165}
166
167////////////////////////////////////////////////////////////////////////////////
168/// Set or change text in text entry.
169
171{
172 if (fText) delete fText;
173 fText = new_text;
175
176 int max_ascent, max_descent;
178 gVirtualX->GetFontProperties(fFontStruct, max_ascent, max_descent);
179 fTHeight = max_ascent + max_descent;
180
181 Resize(fTWidth + 3, fTHeight + 1);
182
183 DoRedraw();
184}
185
186////////////////////////////////////////////////////////////////////////////////
187/// Return default font structure in use for a text listbox entry.
188
190{
191 if (!fgDefaultFont)
192 fgDefaultFont = gClient->GetResourcePool()->GetDefaultFont();
194}
195
196////////////////////////////////////////////////////////////////////////////////
197/// Return default graphics context in use for a text listbox entry.
198
200{
201 if (!fgDefaultGC)
202 fgDefaultGC = new TGGC(*gClient->GetResourcePool()->GetFrameGC());
203 return *fgDefaultGC;
204}
205
206//////////////////////////////////////////////////////////////////////////
207// //
208// TGLineLBEntry //
209// //
210// Line style and width listbox entries. //
211// //
212//////////////////////////////////////////////////////////////////////////
213
214////////////////////////////////////////////////////////////////////////////////
215/// Create the line style listbox entry.
216
217TGLineLBEntry::TGLineLBEntry(const TGWindow *p, Int_t id, const char *str,
218 UInt_t w, Style_t style, UInt_t options, ULong_t back) :
219 TGTextLBEntry(p, new TGString(str), id, GetDefaultGC()(),
220 GetDefaultFontStruct(), options, back)
221{
222 GCValues_t gcv;
223
225 fLineWidth = gcv.fLineWidth = w;
227 gcv.fDashLen = 2;
228 gcv.fDashOffset = 0;
229 memcpy(gcv.fDashes, "\x5\x5", 3);
231 fLineGC = fClient->GetGC(&gcv, kTRUE);
233
234 int max_ascent, max_descent;
235
236 fTWidth = gVirtualX->TextWidth(GetDefaultFontStruct(), "8", 1);
237 fTWidth += 15; // for drawing
238 gVirtualX->GetFontProperties(GetDefaultFontStruct(),
239 max_ascent, max_descent);
240 fTHeight = max_ascent + max_descent;
241 fLineLength = 0;
242
243 Resize(fTWidth, fTHeight + 1);
246}
247
248////////////////////////////////////////////////////////////////////////////////
249/// Delete line style listbox entry.
250
252{
254}
255
256////////////////////////////////////////////////////////////////////////////////
257/// Update line style listbox entry.
258
260{
262
264 fLineGC = ((TGLineLBEntry *)e)->GetLineGC();
266}
267
268////////////////////////////////////////////////////////////////////////////////
269/// Set the line style corresponding to the TPad line styles.
270
272{
273 static const char* dashed = "\x3\x3";
274 static const char* dotted= "\x1\x2";
275 static const char* dasheddotted = "\x3\x4\x1\x4";
276 static const char* ls05 = "\x5\x3\x1\x3";
277 static const char* ls06 = "\x5\x3\x1\x3\x1\x3\x1\x3";
278 static const char* ls07 = "\x5\x5";
279 static const char* ls08 = "\x5\x3\x1\x3\x1\x3";
280 static const char* ls09 = "\x20\x5";
281 static const char* ls10 = "\x20\x10\x1\x10";
282
283
284 if (linestyle <= 1) {
286 } else {
287 switch (linestyle) {
288 case 2:
289 fLineGC->SetDashList(dashed, 2);
290 break;
291 case 3:
292 fLineGC->SetDashList(dotted, 2);
293 break;
294 case 4:
295 fLineGC->SetDashList(dasheddotted, 4);
296 break;
297 case 5:
298 fLineGC->SetDashList(ls05, 4);
299 break;
300 case 6:
301 fLineGC->SetDashList(ls06, 8);
302 break;
303 case 7:
304 fLineGC->SetDashList(ls07, 2);
305 break;
306 case 8:
307 fLineGC->SetDashList(ls08, 6);
308 break;
309 case 9:
310 fLineGC->SetDashList(ls09, 2);
311 break;
312 case 10:
313 fLineGC->SetDashList(ls10, 4);
314 break;
315 }
316 }
317 fLineGC->SetCapStyle(0); // flat cap
318 fLineStyle = linestyle;
319}
320
321////////////////////////////////////////////////////////////////////////////////
322/// Set or change line witdh in an entry.
323
325{
328}
329
330////////////////////////////////////////////////////////////////////////////////
331/// Draw copy on window/pixmap.
332
334{
336 if (!strcmp(TGTextLBEntry::GetTitle(),"None")) return;
337 if (fActive) {
338 gVirtualX->SetForeground(fLineGC->GetGC(),
340 } else {
341 gVirtualX->SetForeground(fLineGC->GetGC(),
343 }
344 gVirtualX->DrawLine(id, fLineGC->GetGC(), x + fTWidth + 5, y + fHeight/2,
345 x + fWidth - 5, y + fHeight/2);
346}
347
348////////////////////////////////////////////////////////////////////////////////
349/// Redraw line style listbox entry.
350
352{
353 if (fId) DrawCopy(fId, 0, 0);
354}
355
356//////////////////////////////////////////////////////////////////////////
357// //
358// TGIconLBEntry //
359// //
360// Icon + text listbox entry. //
361// //
362//////////////////////////////////////////////////////////////////////////
363
364////////////////////////////////////////////////////////////////////////////////
365/// Create the icon & text listbox entry.
366
367TGIconLBEntry::TGIconLBEntry(const TGWindow *p, Int_t id, const char *str,
368 const TGPicture *pic,
369 UInt_t /*w*/, Style_t /*style*/, UInt_t options, ULong_t back) :
370 TGTextLBEntry(p, new TGString(str), id, GetDefaultGC()(),
371 GetDefaultFontStruct(), options, back)
372{
373 int max_ascent, max_descent;
374
375 fPicture = pic;
376 if (fPicture) {
377 fTWidth += fPicture->GetWidth() + 4;
378 ((TGPicture *)fPicture)->AddReference();
379 }
380 else
381 fTWidth += 20;
382 gVirtualX->GetFontProperties(GetDefaultFontStruct(),
383 max_ascent, max_descent);
384 fTHeight = max_ascent + max_descent;
387
388 Resize(fTWidth, fTHeight + 1);
391}
392
393////////////////////////////////////////////////////////////////////////////////
394/// Delete icon & text listbox entry.
395
397{
399}
400
401////////////////////////////////////////////////////////////////////////////////
402/// Update icon & text listbox entry.
403
405{
407}
408
409////////////////////////////////////////////////////////////////////////////////
410/// Draw copy on window/pixmap.
411
413{
414 Int_t off_x = 0;
415 if (fPicture) {
416 fPicture->Draw(id, fNormGC, x + 2, y);
417 off_x = fPicture->GetWidth() + 4;
418 }
419 TGTextLBEntry::DrawCopy(id, x + off_x, y);
420}
421
422////////////////////////////////////////////////////////////////////////////////
423/// Redraw icon & text listbox entry.
424
426{
427 if (fId) DrawCopy(fId, 0, 0);
428}
429
430////////////////////////////////////////////////////////////////////////////////
431/// Change the icon of listbox entry containing icon & text.
432
434{
436
437 if (pic) ((TGPicture *)pic)->AddReference();
438
439 fPicture = pic;
440}
441
442/////////////////////////////////////////////////////////////////////////////////
443class TGLBFrameElement : public TGFrameElement {
444public:
445 TGLBFrameElement(TGFrame *f, TGLayoutHints *l) : TGFrameElement(f, l) {}
446 virtual ~TGLBFrameElement() {}
447
448 Bool_t IsSortable() const { return kTRUE; }
449 Int_t Compare(const TObject *obj) const {
451 return 0;
452 }
453 TGTextLBEntry *f1 = (TGTextLBEntry*)fFrame;
454 TGTextLBEntry *f2 = (TGTextLBEntry *) ((TGFrameElement *) obj)->fFrame;
455
456
457 double d1, d2;
458 const char *t1 = f1->GetText()->Data();
459 const char *t2 = f2->GetText()->Data();
460
461 if ((d1 = atof(t1)) && (d2 = atof(t2))) {
462 return (d1 > d2);
463 } else {
464 return strcmp(t1, t2);
465 }
466 return 0;
467 }
468};
469
470//////////////////////////////////////////////////////////////////////////
471// //
472// TGLBContainer //
473// //
474// A Composite frame that contains a list of TGLBEnties. //
475// A TGLBContainer is for TGListBox internal use. //
476// //
477//////////////////////////////////////////////////////////////////////////
478
479////////////////////////////////////////////////////////////////////////////////
480/// Create a listbox container.
481
483 UInt_t options, ULong_t back) :
484 TGContainer(p, w, h, options, back)
485{
486 fLastActive = 0;
487 fMsgWindow = p;
490 fListBox = 0;
491
494}
495
496////////////////////////////////////////////////////////////////////////////////
497/// Delete the listbox container.
498
500{
501 Cleanup();
502}
503
504////////////////////////////////////////////////////////////////////////////////
505/// Layout container
506
508{
511}
512
513////////////////////////////////////////////////////////////////////////////////
514/// redraw
515
517{
518 return TGContainer::DoRedraw();
519}
520
521////////////////////////////////////////////////////////////////////////////////
522/// Add listbox entry with hints to container. To show entry call
523/// MapSubwindows() and Layout().
524
526{
527 // DEPRECATED: the color should always be set in the TGLBEntry ctor
528 //lbe->SetBackgroundColor(fgWhitePixel);
529
530 TGLBFrameElement *nw = new TGLBFrameElement(lbe, lhints ? lhints : fgDefaultHints);
531 fList->Add(nw);
533}
534
535////////////////////////////////////////////////////////////////////////////////
536/// Insert listbox entry after specified entry with id afterID. If afterID = -1
537/// then add entry at head of list. To show entry call MapSubwindows() and
538/// Layout().
539
541{
542 // DEPRECATED: the color should always be set in the TGLBEntry ctor
543 //lbe->SetBackgroundColor(fgWhitePixel);
544
545 TGLBEntry *e;
546 TGFrameElement *el, *nw;
547 TIter next(fList);
548
549 while ((el = (TGFrameElement *) next())) {
550 e = (TGLBEntry *) el->fFrame;
551 if (e->EntryId() == afterID) break;
552 }
553
554 if (!el && afterID != -1) {
555 nw = new TGLBFrameElement(lbe, lhints ? lhints : fgDefaultHints);
556 fList->Add(nw);
557 } else {
558 nw = new TGLBFrameElement(lbe, lhints);
559 nw->fFrame = lbe;
560 nw->fLayout = lhints;
561 nw->fState = 1;
562 //lbe->SetFrameElement(nw);
563
564 if (afterID == -1)
565 fList->AddFirst(nw);
566 else
567 fList->AddAfter(el, nw);
568 }
570}
571
572////////////////////////////////////////////////////////////////////////////////
573/// Insert listbox entry before the list box entry with a higher id.
574/// To show entry call MapSubwindows() and Layout().
575
577{
578 // DEPRECATED: the color should always be set in the TGLBEntry ctor
579 //lbe->SetBackgroundColor(fgWhitePixel);
580
581 TGLBEntry *e;
582 TGFrameElement *el, *nw;
583 TIter next(fList);
584
585 while ((el = (TGFrameElement *) next())) {
586 e = (TGLBEntry *) el->fFrame;
587 if (e->EntryId() > lbe->EntryId()) break;
588 }
589
590 if (!el) {
591 nw = new TGLBFrameElement(lbe, lhints ? lhints : fgDefaultHints);
592 fList->Add(nw);
593 } else {
594 nw = new TGLBFrameElement(lbe, lhints);
595 nw->fFrame = lbe;
596 nw->fLayout = lhints;
597 nw->fState = 1;
598 //lbe->SetFrameElement(nw);
599
600 fList->AddBefore(el, nw);
601 }
603}
604
605////////////////////////////////////////////////////////////////////////////////
606/// Remove the entry with specified id from the listbox container.
607/// To update the listbox call Layout().
608
610{
611 TGLBEntry *e;
612 TGFrameElement *el;
614
615 TIter next(fList);
616
617 while ((el = (TGFrameElement *) next())) {
618 e = (TGLBEntry *) el->fFrame;
619 l = el->fLayout;
620 if (e->EntryId() == id) {
621 if (fLastActive == e) fLastActive = 0;
622 e->DestroyWindow();
623 fList->Remove(el); // avoid calling RemoveFrame(e)
624 delete el; // item
625 delete e;
626 delete l;
627 break;
628 }
629 }
631}
632
633////////////////////////////////////////////////////////////////////////////////
634/// Remove entries from from_ID to to_ID (including).
635/// To update the listbox call Layout().
636
638{
639 TGLBEntry *e;
640 TGFrameElement *el;
642
643 TIter next(fList);
644
645 while ((el = (TGFrameElement *) next())) {
646 e = (TGLBEntry *) el->fFrame;
647 l = el->fLayout;
648 if ((e->EntryId() >= from_ID) && (e->EntryId() <= to_ID)) {
649 if (fLastActive == e) fLastActive = 0;
650 e->DestroyWindow();
651 fList->Remove(el); // avoid calling RemoveFrame(e)
652 delete el; // idem
653 delete e;
654 delete l;
655 }
656 }
658}
659
660////////////////////////////////////////////////////////////////////////////////
661/// Remove all entries in this container.
662
664{
665 TGLBEntry *e;
666 TGFrameElement *el;
668
669 TIter next(fList);
670
671 while ((el = (TGFrameElement *) next())) {
672 e = (TGLBEntry *) el->fFrame;
673 l = el->fLayout;
674 if (fLastActive == e) fLastActive = 0;
675 e->DestroyWindow();
676 fList->Remove(el); // avoid calling RemoveFrame(e)
677 delete el; // item
678 delete e;
679 delete l;
680 }
682}
683
684////////////////////////////////////////////////////////////////////////////////
685/// Select the entry with the specified id.
686/// Returns the selected TGLBEntry.
687
689{
690 return Select(id, kTRUE);
691}
692
693////////////////////////////////////////////////////////////////////////////////
694/// Select / deselect the entry with the specified id.
695/// Returns the selected TGLBEntry.
696
698{
699 TGLBEntry *f;
700 TGFrameElement *el;
701
702 if (!fMultiSelect && fLastActive) {
704 fLastActive = 0;
705 }
706
707 TIter next(fList);
708 while ((el = (TGFrameElement *) next())) {
709 f = (TGLBEntry *) el->fFrame;
710 if (f->EntryId() == id) {
711 f->Activate(sel);
712 if (fMultiSelect == kFALSE && sel == kTRUE) {
713 fLastActive = f;
714 fLastActiveEl = el;
715 }
717 return f;
718 }
719 }
720
721 return 0;
722}
723
724////////////////////////////////////////////////////////////////////////////////
725/// Returns id of selected entry. In case of no selected entry or
726/// if multi selection is switched on returns -1.
727
729{
730 if (fLastActive == 0) return -1;
731 return fLastActive->EntryId();
732}
733
734////////////////////////////////////////////////////////////////////////////////
735/// Returns kTrue if entry id is selected.
736
738{
739 TGLBEntry *f;
740 TGFrameElement *el;
741
742 TIter next(fList);
743 while ((el = (TGFrameElement *) next())) {
744 f = (TGLBEntry *) el->fFrame;
745 if (f->EntryId() == id)
746 return f->IsActive();
747 }
748
749 return kFALSE;
750}
751
752////////////////////////////////////////////////////////////////////////////////
753/// Adds all selected entries (TGLBEntry) of the list box into
754/// the list selected.
755
757{
758 TGLBEntry *f;
759 TGFrameElement *el;
760
761 TIter next(fList);
762 while ((el = (TGFrameElement *) next())) {
763 f = (TGLBEntry *) el->fFrame;
764 if (f->IsActive()) {
765 selected->Add(f);
766 }
767 }
768}
769
770////////////////////////////////////////////////////////////////////////////////
771/// Enables and disables multiple selections of entries.
772
774{
775 TGFrameElement *el;
776
777 fMultiSelect = multi;
778 if (!fMultiSelect) {
779 // deselect all entries
780 TIter next(fList);
781 while ((el = (TGFrameElement *) next())) {
782 ((TGLBEntry *)(el->fFrame))->Activate(kFALSE);
783 }
784 }
785 fLastActive = 0;
786 fLastActiveEl = 0;
788}
789
790////////////////////////////////////////////////////////////////////////////////
791/// Return a pointer to vertical scroll bar.
792
794{
795 return fListBox ? fListBox->GetVScrollbar() : 0;
796}
797
798////////////////////////////////////////////////////////////////////////////////
799/// Set new vertical scroll bar position.
800
802{
804
805 if (vb && vb->IsMapped()) {
806 vb->SetPosition(newPos);
807 }
808}
809
810////////////////////////////////////////////////////////////////////////////////
811/// Handle mouse button event in the listbox container.
812
814{
815 int xf0, yf0, xff, yff;
816
817 TGLBEntry *f;
818 TGFrameElement *el;
819 TGLBEntry *last = fLastActive;
820
822 Int_t x = pos.fX + event->fX;
823 Int_t y = pos.fY + event->fY;
824 Bool_t activate = kFALSE;
825
826 // do not handle "context menu button" during guibuilding
827 if (fClient->IsEditable() && (event->fCode == kButton3)) {
828 return kTRUE;
829 }
830
832
833 if ((event->fCode == kButton4) && vb){
834 // scroll 2 lines up (a button down is always followed by a button up)
835 Int_t newpos = vb->GetPosition() - 1;
836 if (newpos < 0) newpos = 0;
837 vb->SetPosition(newpos);
839 return kTRUE;
840 }
841 if ((event->fCode == kButton5) && vb) {
842 // scroll 2 lines down (a button down is always followed by a button up)
843 Int_t newpos = vb->GetPosition() + 1;
844 vb->SetPosition(newpos);
846 return kTRUE;
847 }
848
849 gVirtualX->SetInputFocus(fId);
850
851 if (fMultiSelect) {
852 if (event->fType == kButtonPress) {
853 TIter next(fList);
854 while ((el = (TGFrameElement *) next())) {
855 f = (TGLBEntry *) el->fFrame;
856 xf0 = f->GetX();
857 yf0 = f->GetY();
858 xff = xf0 + f->GetWidth();
859 yff = yf0 + f->GetHeight();
860
861 activate = fMapSubwindows ? (f->GetId() == (Window_t)event->fUser[0]) :
862 (x > xf0) && (x < xff) && (y > yf0) && (y < yff);
863
864 if (activate) {
865 fLastActive = f;
866 fLastActiveEl = el;
867 f->Toggle();
868 fChangeStatus = f->IsActive() ? 1 : 0;
870 f->EntryId(), 0);
871 break;
872 }
873 }
874 } else {
875 fChangeStatus = -1;
876 }
877 } else {
878 if (event->fType == kButtonPress) {
879 if (fLastActive) {
881 fLastActive = 0;
882 }
883 TIter next(fList);
884 while ((el = (TGFrameElement *) next())) {
885 f = (TGLBEntry *) el->fFrame;
886 xf0 = f->GetX();
887 yf0 = f->GetY();
888 xff = xf0 + f->GetWidth();
889 yff = yf0 + f->GetHeight();
890
891 activate = fMapSubwindows ? (f->GetId() == (Window_t)event->fUser[0]) :
892 (x > xf0) && (x < xff) && (y > yf0) && (y < yff) && !f->IsActive();
893
894 if (activate) {
895 f->Activate(kTRUE);
896 fLastActive = f;
897 fLastActiveEl = el;
898 } else {
899 f->Activate(kFALSE);
900 }
901 }
902 } else {
903 if (fLastActive) {
904 f = fLastActive;
906 f->EntryId(), 0);
907 }
908 }
909 }
910 if (event->fType == kButtonRelease) {
913 }
914 if (fChangeStatus || (last != fLastActive))
916 // trick to avoid mouse move events between the mouse click
917 // and the unmapping...
918 if (fListBox->GetParent()->InheritsFrom("TGComboBoxPopup"))
920 return kTRUE;
921}
922
923////////////////////////////////////////////////////////////////////////////////
924/// Handle double click mouse event in the listbox container.
925
927{
928 if (!fMultiSelect) {
929 if (fLastActive) {
932 f->EntryId(), 0);
933 DoubleClicked(f, ev->fCode);
934 DoubleClicked(f, ev->fCode, ev->fXRoot, ev->fYRoot);
935 }
936 return kTRUE;
937 }
939}
940
941////////////////////////////////////////////////////////////////////////////////
942/// Handle mouse motion event in listbox container.
943
945{
946 int xf0, yf0, xff, yff;
947
948 static Long64_t was = gSystem->Now();
949 Long64_t now = gSystem->Now();
950
951 if ((now-was) < 50) return kFALSE;
952 was = now;
953
954 TGLBEntry *f;
955 TGFrameElement *el;
958 Int_t x = pos.fX + event->fX;
959 Int_t y = pos.fY + event->fY;
960 Bool_t activate = kFALSE;
961 TGLBEntry *last = fLastActive;
962
963 if (fMultiSelect) {
964
965 if ((event->fY < 10) || (event->fY > Int_t(dim.fHeight) - 10)) {
966 if (!fScrolling) {
969 }
971 }
972 else if (fChangeStatus >= 0) {
973 TIter next(fList);
974 while ((el = (TGFrameElement *) next())) {
975 f = (TGLBEntry *) el->fFrame;
976 xf0 = f->GetX();
977 yf0 = f->GetY();
978 xff = xf0 + f->GetWidth();
979 yff = yf0 + f->GetHeight();
980 activate = fMapSubwindows ? (f->GetId() == (Window_t)event->fUser[0]) :
981 (x > xf0) && (x < xff) && (y > yf0) && (y < yff);
982
983 if (activate) {
984 if (fChangeStatus != (f->IsActive() ? 1 : 0)) {
985 f->Toggle();
988 f->EntryId(), 0);
989 }
990 break;
991 }
992 }
993 }
994 } else if (fListBox->GetParent()->InheritsFrom("TGComboBoxPopup")) {
995 TIter next(fList);
996 while ((el = (TGFrameElement *) next())) {
997 f = (TGLBEntry *) el->fFrame;
998 xf0 = f->GetX();
999 yf0 = f->GetY();
1000 xff = xf0 + f->GetWidth();
1001 yff = yf0 + f->GetHeight();
1002
1003 activate = fMapSubwindows ? (f->GetId() == (Window_t)event->fUser[0]) :
1004 (x > xf0) && (x < xff) && (y > yf0) && (y < yff) && !f->IsActive();
1005
1006 if (activate) {
1007 f->Activate(kTRUE);
1008 fLastActive = f;
1009 fLastActiveEl = el;
1010 } else {
1011 f->Activate(kFALSE);
1012 }
1013 if (last != fLastActive) {
1014 ClearViewPort();
1015 }
1016 }
1017 }
1018 return kTRUE;
1019}
1020
1021////////////////////////////////////////////////////////////////////////////////
1022/// Autoscroll while close to & beyond The Wall
1023
1025{
1026 TGFrameElement* el = 0;
1027 TGLBEntry *f = 0;
1028 Int_t yf0, yff;
1029 Bool_t changed = kFALSE;
1030
1033
1034 Window_t dum1, dum2;
1035 Event_t ev;
1036 ev.fType = kButtonPress;
1037 Int_t x, y;
1038
1039 // Where's the cursor?
1040 gVirtualX->QueryPointer(fId,dum1,dum2,ev.fXRoot,ev.fYRoot,x,y,ev.fState);
1042 if (vb && y > 0 && y < 10) {
1043 // scroll 1 line up
1044 Int_t newpos = vb->GetPosition() - 1;
1045 if (newpos < 0) newpos = 0;
1046 vb->SetPosition(newpos);
1047 changed = kTRUE;
1048 }
1049 else if (vb && y > (Int_t)dim.fHeight - 10 && y < (Int_t)dim.fHeight) {
1050 // scroll 1 line down
1051 Int_t newpos = vb->GetPosition() + 1;
1052 vb->SetPosition(newpos);
1053 changed = kTRUE;
1054 }
1055 if (changed && fChangeStatus >= 0) {
1056 pos = GetPagePosition();
1057 TIter next(fList);
1058 while ((el = (TGFrameElement *) next())) {
1059 f = (TGLBEntry *) el->fFrame;
1060 yf0 = f->GetY();
1061 yff = yf0 + f->GetHeight();
1062 if ((y + pos.fY > yf0) && (y + pos.fY < yff)) {
1063 if (fChangeStatus != (f->IsActive() ? 1 : 0)) {
1064 f->Toggle();
1065 ClearViewPort();
1067 f->EntryId(), 0);
1068 }
1069 break;
1070 }
1071 }
1072 }
1073}
1074
1075////////////////////////////////////////////////////////////////////////////////
1076/// Activate item.
1077
1079{
1081 fLastActive = (TGLBEntry *)el->fFrame;
1082}
1083
1084////////////////////////////////////////////////////////////////////////////////
1085/// Returns the position in the list box of the entry id.
1086/// The first position has position no 0. Returns -1 if entry id
1087/// is not in the list of entries.
1088
1090{
1091 Int_t pos = 0;
1092 TGLBEntry *f;
1093 TGFrameElement *el;
1094
1095 TIter next(fList);
1096 while ((el = (TGFrameElement *) next())) {
1097 f = (TGLBEntry *) el->fFrame;
1098 if (f->EntryId() == id)
1099 return pos;
1100 pos++;
1101 }
1102
1103 return -1;
1104}
1105
1106
1107//////////////////////////////////////////////////////////////////////////
1108// //
1109// TGListBox //
1110// //
1111// A listbox contains a container frame which is viewed through a //
1112// viewport. If the container is larger than the viewport than a //
1113// vertical scrollbar is added. //
1114// //
1115// Selecting an item in the listbox will generate the event: //
1116// kC_COMMAND, kCM_LISTBOX, listbox id, item id. //
1117// //
1118//////////////////////////////////////////////////////////////////////////
1119
1120////////////////////////////////////////////////////////////////////////////////
1121/// Create a listbox.
1122
1124 UInt_t options, ULong_t back) :
1125 TGCompositeFrame(p, 10, 10, options, back)
1126{
1127 fMsgWindow = p;
1128 fWidgetId = id;
1129
1130 fItemVsize = 1;
1132
1133 InitListBox();
1134}
1135
1136////////////////////////////////////////////////////////////////////////////////
1137/// Delete a listbox widget.
1138
1140{
1141 if (!MustCleanup()) {
1142 delete fVScrollbar;
1143 delete fVport;
1144 delete fLbc;
1145 }
1146}
1147
1148////////////////////////////////////////////////////////////////////////////////
1149/// Initiate the internal classes of a list box.
1150
1152{
1157 fLbc->Associate(this);
1158 fLbc->SetListBox(this);
1160
1161 AddFrame(fVport, 0);
1163
1164 fVScrollbar->Associate(this);
1165
1170
1175
1176 // layout manager is not used
1177 delete fLayoutManager;
1178 fLayoutManager = 0;
1179}
1180
1181////////////////////////////////////////////////////////////////////////////////
1182/// Draw borders of the list box widget.
1183
1185{
1187
1189 gVirtualX->DrawLine(fId, GetShadowGC()(), 0, 0, fWidth-2, 0);
1190 gVirtualX->DrawLine(fId, GetShadowGC()(), 0, 0, 0, fHeight-2);
1191 gVirtualX->DrawLine(fId, GetBlackGC()(), 1, 1, fWidth-3, 1);
1192 gVirtualX->DrawLine(fId, GetBlackGC()(), 1, 1, 1, fHeight-3);
1193 if (gClient->GetStyle() > 1) break;
1194 gVirtualX->DrawLine(fId, GetHilightGC()(), 0, fHeight-1, fWidth-1, fHeight-1);
1195 gVirtualX->DrawLine(fId, GetHilightGC()(), fWidth-1, fHeight-1, fWidth-1, 0);
1196 gVirtualX->DrawLine(fId, GetBckgndGC()(), 1, fHeight-2, fWidth-2, fHeight-2);
1197 gVirtualX->DrawLine(fId, GetBckgndGC()(), fWidth-2, 1, fWidth-2, fHeight-2);
1198 break;
1199
1200 default:
1202 break;
1203 }
1204}
1205
1206////////////////////////////////////////////////////////////////////////////////
1207/// Add entry with specified string and id to listbox. The id will be
1208/// used in the event processing routine when the item is selected.
1209/// The string will be adopted by the listbox.
1210
1212{
1213 TGTextLBEntry *lbe;
1214 TGLayoutHints *lhints;
1215
1216 lbe = new TGTextLBEntry(fLbc, s, id);
1217 lhints = new TGLayoutHints(kLHintsExpandX | kLHintsTop);
1219 fLbc->AddEntry(lbe, lhints);
1220}
1221
1222////////////////////////////////////////////////////////////////////////////////
1223/// Add entry with specified string and id to listbox. The id will be
1224/// used in the event processing routine when the item is selected.
1225
1226void TGListBox::AddEntry(const char *s, Int_t id)
1227{
1228 AddEntry(new TGString(s), id);
1229}
1230
1231////////////////////////////////////////////////////////////////////////////////
1232/// Add specified TGLBEntry and TGLayoutHints to listbox. The
1233/// entry and layout will be adopted and later deleted by the listbox.
1234
1236{
1238 fLbc->AddEntry(lbe, lhints);
1239}
1240
1241////////////////////////////////////////////////////////////////////////////////
1242/// Add entry with specified string and id to listbox sorted by increasing id.
1243/// This sorting works proberly only if EntrySort functions are used to add
1244/// entries without mixing them with other add or insert functions. The id will be
1245/// used in the event processing routine when the item is selected.
1246/// The string will be adopted by the listbox.
1247
1249{
1250 TGTextLBEntry *lbe;
1251 TGLayoutHints *lhints;
1252
1253 lbe = new TGTextLBEntry(fLbc, s, id);
1254 lhints = new TGLayoutHints(kLHintsExpandX | kLHintsTop);
1256 fLbc->AddEntrySort(lbe, lhints);
1257}
1258
1259////////////////////////////////////////////////////////////////////////////////
1260/// Add entry with specified string and id to listbox sorted by increasing id.
1261/// This sorting works proberly only if EntrySort functions are used to add
1262/// entries without mixing them with other add or insert functions. The id will be
1263/// used in the event processing routine when the item is selected.
1264
1265void TGListBox::AddEntrySort(const char *s, Int_t id)
1266{
1267 AddEntrySort(new TGString(s), id);
1268}
1269
1270////////////////////////////////////////////////////////////////////////////////
1271/// Add specified TGLBEntry and TGLayoutHints to listbox sorted by increasing id.
1272/// This sorting works proberly only if EntrySort functions are used to add
1273/// entries without mixing them with other add or insert functions. The
1274/// entry and layout will be adopted and later deleted by the listbox.
1275
1277{
1279 fLbc->AddEntrySort(lbe, lhints);
1280}
1281
1282////////////////////////////////////////////////////////////////////////////////
1283/// Insert entry with specified string and id behind the entry with afterID.
1284/// The string will be adopted and later deleted by the listbox.
1285
1287{
1288 TGTextLBEntry *lbe;
1289 TGLayoutHints *lhints;
1290
1291 lbe = new TGTextLBEntry(fLbc, s, id);
1292 lhints = new TGLayoutHints(kLHintsExpandX | kLHintsTop);
1294 fLbc->InsertEntry(lbe, lhints, afterID);
1295}
1296
1297////////////////////////////////////////////////////////////////////////////////
1298/// Insert entry with specified string and id behind the entry with afterID.
1299
1300void TGListBox::InsertEntry(const char *s, Int_t id, Int_t afterID)
1301{
1302 InsertEntry(new TGString(s), id, afterID);
1303}
1304
1305////////////////////////////////////////////////////////////////////////////////
1306/// method used to add entry via context menu
1307
1308void TGListBox::NewEntry(const char *s)
1309{
1310 Int_t selected = fLbc->GetSelected();
1311
1312 // no selected entry or the last entry
1313 if ((selected < 0) || (selected == GetNumberOfEntries())) {
1315 } else {
1316 InsertEntry(s, GetNumberOfEntries()+1, selected);
1317 }
1318 Layout();
1319}
1320
1321////////////////////////////////////////////////////////////////////////////////
1322/// remove entry with id.
1323/// If id = -1 - the selected entry/entries is/are removed.
1324///
1325
1327{
1328 if (id >= 0) {
1329 fLbc->RemoveEntry(id);
1330 Layout();
1331 return;
1332 }
1333 if (!fLbc->GetMultipleSelections()) {
1335 Layout();
1336 return;
1337 }
1338 TList li;
1340 TGLBEntry *e;
1341 TIter next(&li);
1342
1343 while ((e = (TGLBEntry*)next())) {
1344 fLbc->RemoveEntry(e->EntryId());
1345 }
1346 Layout();
1347}
1348
1349////////////////////////////////////////////////////////////////////////////////
1350/// Remove all entries.
1351
1353{
1354 fLbc->RemoveAll();
1355 Layout();
1356}
1357
1358////////////////////////////////////////////////////////////////////////////////
1359/// Remove a range of entries defined by from_ID and to_ID.
1360
1362{
1363 fLbc->RemoveEntries(from_ID, to_ID);
1364 Layout();
1365}
1366
1367////////////////////////////////////////////////////////////////////////////////
1368/// Insert the specified TGLBEntry and layout hints behind afterID.
1369/// The entry and layout will be adopted and later deleted by the listbox.
1370
1371void TGListBox::InsertEntry(TGLBEntry *lbe, TGLayoutHints *lhints, int afterID)
1372{
1374 fLbc->InsertEntry(lbe, lhints, afterID);
1375}
1376
1377////////////////////////////////////////////////////////////////////////////////
1378/// Returns list box entry with specified id.
1379
1381{
1382 TIter next(fLbc->GetList());
1383 TGFrameElement *el;
1384
1385 while ((el = (TGFrameElement *)next())) {
1386 TGLBEntry *lbe = (TGLBEntry *)el->fFrame;
1387 if (lbe->EntryId() == id) return lbe;
1388 }
1389 return 0;
1390}
1391
1392////////////////////////////////////////////////////////////////////////////////
1393/// Scroll the entry with id to the top of the listbox.
1394
1396{
1397 Int_t idPos;
1398
1399 idPos = fLbc->GetPos(id);
1400
1401 // id not found in list of entries
1402 if (idPos < 0)
1403 return;
1404
1405 // call layout to define the range of the scroll bars
1406 Layout();
1407
1408 // SetPosition will send a message which will handled by
1409 // the function TGListBox::ProcessMessage. Now ProcessMessage will
1410 // set the viewport. SetPosition also will check that the idPos is
1411 // not out of range.
1412 fVScrollbar->SetPosition(idPos);
1413}
1414
1415////////////////////////////////////////////////////////////////////////////////
1416/// Resize the listbox widget. If fIntegralHeight is true make the height
1417/// an integral number of the maximum height of a single entry.
1418
1420{
1421 if (fIntegralHeight)
1423 + (fBorderWidth << 1);
1424
1426 DoRedraw();
1427}
1428
1429////////////////////////////////////////////////////////////////////////////////
1430/// Move and resize the listbox widget.
1431
1433{
1434 if (fIntegralHeight)
1436 + (fBorderWidth << 1);
1438 DoRedraw();
1439}
1440
1441////////////////////////////////////////////////////////////////////////////////
1442/// Return default size of listbox widget.
1443
1445{
1446 UInt_t h;
1447
1448 if (fIntegralHeight)
1450 + (fBorderWidth << 1);
1451 else
1452 h = fHeight;
1453
1454 return TGDimension(fWidth, h);
1455}
1456
1457////////////////////////////////////////////////////////////////////////////////
1458/// Layout the listbox components.
1459
1461{
1462 TGFrame *container;
1463 UInt_t cw, ch, tch;
1464 Bool_t need_vsb;
1465
1466 need_vsb = kFALSE;
1467
1468 container = fVport->GetContainer();
1469
1470 // test whether we need vertical scrollbar or not
1471
1472 cw = fWidth - (fBorderWidth << 1);
1473 ch = fHeight - (fBorderWidth << 1);
1474
1475 container->SetWidth(cw);
1476 container->SetHeight(ch);
1477
1478 if (container->GetDefaultHeight() > ch) {
1479 need_vsb = kTRUE;
1481 if ((Int_t) cw < 0) {
1482 Warning("Layout", "width would become too small, setting to 10");
1483 cw = 10;
1484 }
1485 container->SetWidth(cw);
1486 }
1487
1489 container->Layout();
1490
1491 tch = TMath::Max(container->GetDefaultHeight(), ch);
1492 container->SetHeight(0); // force a resize in TGFrame::Resize
1493 container->Resize(cw, tch);
1494 //fVport->SetPos(0, 0);
1495
1496 if (need_vsb) {
1499 } else {
1502 }
1503
1506 //fClient->NeedRedraw(container);
1507 ((TGContainer *)container)->ClearViewPort();
1508}
1509
1510////////////////////////////////////////////////////////////////////////////////
1511/// Sort entries by name
1512
1514{
1515 fLbc->GetList()->Sort(ascend);
1516 Layout();
1518}
1519
1520////////////////////////////////////////////////////////////////////////////////
1521/// Return id of selected listbox item.
1522
1524{
1526 return ct->GetSelected();
1527}
1528
1529////////////////////////////////////////////////////////////////////////////////
1530/// Adds all selected entries (TGLBEntry) of the list box into
1531/// the list selected.
1532
1534{
1535 fLbc->GetSelectedEntries(selected);
1536}
1537
1538////////////////////////////////////////////////////////////////////////////////
1539/// Change background to all entries
1540
1542{
1543 fBackground = back;
1544
1545 TIter next(fLbc->GetList());
1546 TGFrameElement *el;
1547
1548 while ((el = (TGFrameElement *)next())) {
1549 TGLBEntry *lbe = (TGLBEntry *)el->fFrame;
1550 lbe->SetBackgroundColor(back);
1551 }
1553}
1554
1555////////////////////////////////////////////////////////////////////////////////
1556/// Process messages generated by the listbox container and forward
1557/// messages to the listbox message handling window.
1558
1560{
1561 switch (GET_MSG(msg)) {
1562 case kC_VSCROLL:
1563 switch (GET_SUBMSG(msg)) {
1564 case kSB_SLIDERTRACK:
1565 case kSB_SLIDERPOS:
1566 fVport->SetVPos(Int_t(-parm1 * fItemVsize));
1567 break;
1568 }
1569 break;
1570
1571 case kC_CONTAINER:
1572 switch (GET_SUBMSG(msg)) {
1573 case kCT_ITEMCLICK:
1574 {
1576 fWidgetId, parm1);
1578 TGLBEntry *entry = GetSelectedEntry();
1579 if (entry) {
1580 if (entry->InheritsFrom(TGTextLBEntry::Class())) {
1581 const char *text;
1582 text = ((TGTextLBEntry*)entry)->GetText()->GetString();
1583 Selected(text);
1584 }
1585 Selected(fWidgetId, (Int_t) parm1);
1586 Selected((Int_t) parm1);
1587 }
1588 }
1589 break;
1590 case kCT_ITEMDBLCLICK:
1591 if (!GetMultipleSelections()) {
1592 TGLBEntry *entry = GetSelectedEntry();
1593 if (entry) {
1594 if (entry->InheritsFrom(TGTextLBEntry::Class())) {
1595 const char *text;
1596 text = ((TGTextLBEntry*)entry)->GetText()->GetString();
1598 }
1599 DoubleClicked(fWidgetId, (Int_t) parm1);
1600 DoubleClicked((Int_t) parm1);
1601 }
1602 }
1603 break;
1604 }
1605 break;
1606
1607 default:
1608 break;
1609
1610 }
1611 return kTRUE;
1612}
1613
1614////////////////////////////////////////////////////////////////////////////////
1615/// Emit Selected signal with list box id and entry id.
1616
1618{
1619 Long_t args[2];
1620
1621 args[0] = widgetId;
1622 args[1] = id;
1623
1624 Emit("Selected(Int_t,Int_t)", args);
1625}
1626
1627////////////////////////////////////////////////////////////////////////////////
1628/// Emit DoubleClicked signal with list box id and entry id.
1629
1631{
1632 Long_t args[2];
1633
1634 args[0] = widgetId;
1635 args[1] = id;
1636
1637 Emit("DoubleClicked(Int_t,Int_t)", args);
1638}
1639
1640////////////////////////////////////////////////////////////////////////////////
1641/// Find entry by name.
1642
1644{
1645 TList *list = fLbc->GetList();
1646 TGFrameElement *el = (TGFrameElement *)list->First();
1647 while (el) {
1648 if (el->fFrame->GetTitle() == TString(name))
1649 return (TGLBEntry *)el->fFrame;
1650 el = (TGFrameElement *)list->After(el);
1651 }
1652 return 0;
1653}
1654
1655////////////////////////////////////////////////////////////////////////////////
1656/// Save a list box widget as a C++ statement(s) on output stream out.
1657
1658void TGListBox::SavePrimitive(std::ostream &out, Option_t *option /*= ""*/)
1659{
1660 if (fBackground != GetWhitePixel()) SaveUserColor(out, option);
1661
1662 out << std::endl << " // list box" << std::endl;
1663
1664 out<<" TGListBox *";
1665 out << GetName() << " = new TGListBox(" << fParent->GetName();
1666
1667 if (fBackground == GetWhitePixel()) {
1668 if (GetOptions() == (kSunkenFrame | kDoubleBorder)) {
1669 if (fWidgetId == -1) {
1670 out <<");" << std::endl;
1671 } else {
1672 out << "," << fWidgetId << ");" << std::endl;
1673 }
1674 } else {
1675 out << "," << fWidgetId << "," << GetOptionString() <<");" << std::endl;
1676 }
1677 } else {
1678 out << "," << fWidgetId << "," << GetOptionString() << ",ucolor);" << std::endl;
1679 }
1680 if (option && strstr(option, "keep_names"))
1681 out << " " << GetName() << "->SetName(\"" << GetName() << "\");" << std::endl;
1682
1683 if (!fLbc->GetList()) return;
1684
1685 TGFrameElement *el;
1686 TIter next(fLbc->GetList());
1687
1688 while ((el = (TGFrameElement *) next())) {
1689 out << " " << GetName() << "->AddEntry(";
1690 el->fFrame->SavePrimitive(out, option);
1691 out << ");"<< std::endl;
1692 }
1693 out << " " << GetName() << "->Resize(" << GetWidth() << "," << GetHeight()
1694 << ");" << std::endl;
1695}
1696
1697////////////////////////////////////////////////////////////////////////////////
1698/// Save a list box entry widget as a C++ statement(s) on output stream out.
1699
1700void TGTextLBEntry::SavePrimitive(std::ostream &out, Option_t * /*= ""*/)
1701{
1702 TString content = GetText()->GetString();
1703 content.ReplaceAll('\\', "\\\\");
1704 content.ReplaceAll("\"", "\\\"");
1705 char quote = '"';
1706 out << quote << content << quote << "," << EntryId();
1707}
void Class()
Definition: Class.C:29
@ kDefaultScrollBarWidth
Definition: GuiTypes.h:85
@ kButtonRelease
Definition: GuiTypes.h:59
@ kButtonPress
Definition: GuiTypes.h:59
const Mask_t kGCLineStyle
Definition: GuiTypes.h:290
const Mask_t kGCLineWidth
Definition: GuiTypes.h:289
const Mask_t kButtonMotionMask
Definition: GuiTypes.h:163
ULong_t Handle_t
Definition: GuiTypes.h:25
const Mask_t kButtonPressMask
Definition: GuiTypes.h:160
const Mask_t kGCDashList
Definition: GuiTypes.h:306
const Mask_t kGCFillStyle
Definition: GuiTypes.h:293
const Mask_t kPointerMotionMask
Definition: GuiTypes.h:162
@ kFillSolid
Definition: GuiTypes.h:50
@ kLineSolid
Definition: GuiTypes.h:47
@ kLineOnOffDash
Definition: GuiTypes.h:47
Handle_t GContext_t
Definition: GuiTypes.h:37
const Mask_t kButtonReleaseMask
Definition: GuiTypes.h:161
Handle_t FontStruct_t
Definition: GuiTypes.h:38
ULong_t Pixel_t
Definition: GuiTypes.h:39
@ kButton4
Definition: GuiTypes.h:214
@ kButton5
Definition: GuiTypes.h:214
@ kButton3
Definition: GuiTypes.h:213
Handle_t Window_t
Definition: GuiTypes.h:28
#define f(i)
Definition: RSha256.hxx:104
#define h(i)
Definition: RSha256.hxx:106
#define e(i)
Definition: RSha256.hxx:103
int Int_t
Definition: RtypesCore.h:41
unsigned int UInt_t
Definition: RtypesCore.h:42
const Bool_t kFALSE
Definition: RtypesCore.h:88
unsigned long ULong_t
Definition: RtypesCore.h:51
long Long_t
Definition: RtypesCore.h:50
bool Bool_t
Definition: RtypesCore.h:59
double Double_t
Definition: RtypesCore.h:55
long long Long64_t
Definition: RtypesCore.h:69
short Style_t
Definition: RtypesCore.h:76
const Bool_t kTRUE
Definition: RtypesCore.h:87
const char Option_t
Definition: RtypesCore.h:62
#define ClassImp(name)
Definition: Rtypes.h:365
include TDocParser_001 C image html pict1_TDocParser_001 png width
Definition: TDocParser.cxx:121
#define gClient
Definition: TGClient.h:166
@ kChildFrame
Definition: TGFrame.h:57
@ kRaisedFrame
Definition: TGFrame.h:62
@ kSunkenFrame
Definition: TGFrame.h:61
@ kVerticalFrame
Definition: TGFrame.h:59
@ kDoubleBorder
Definition: TGFrame.h:63
@ kOwnBackground
Definition: TGFrame.h:69
@ kLHintsTop
Definition: TGLayout.h:34
@ kLHintsExpandX
Definition: TGLayout.h:37
XFontStruct * id
Definition: TGX11.cxx:108
char name[80]
Definition: TGX11.cxx:109
R__EXTERN TSystem * gSystem
Definition: TSystem.h:560
#define gVirtualX
Definition: TVirtualX.h:345
Int_t MK_MSG(EWidgetMessageTypes msg, EWidgetMessageTypes submsg)
Int_t GET_MSG(Long_t val)
@ kSB_SLIDERTRACK
@ kSB_SLIDERPOS
@ kC_VSCROLL
@ kCT_ITEMCLICK
@ kC_COMMAND
@ kCM_LISTBOX
@ kCT_ITEMDBLCLICK
@ kC_CONTAINER
Int_t GET_SUBMSG(Long_t val)
Bool_t IsEditable() const
Definition: TGClient.h:98
TGGC * GetGC(GCValues_t *values, Bool_t rw=kFALSE)
Get graphics context from the gc pool.
Definition: TGClient.cxx:320
void FreeGC(const TGGC *gc)
Free a graphics context.
Definition: TGClient.cxx:328
const TGResourcePool * GetResourcePool() const
Definition: TGClient.h:133
void FreePicture(const TGPicture *pic)
Free picture resource.
Definition: TGClient.cxx:308
TGLayoutManager * fLayoutManager
Definition: TGFrame.h:350
virtual TList * GetList() const
Definition: TGFrame.h:369
virtual void AddFrame(TGFrame *f, TGLayoutHints *l=0)
Add frame to the composite frame using the specified layout hints.
Definition: TGFrame.cxx:1099
virtual void Cleanup()
Cleanup and delete all objects contained in this composite frame.
Definition: TGFrame.cxx:949
virtual Int_t MustCleanup() const
Definition: TGFrame.h:420
Bool_t fMapSubwindows
Definition: TGFrame.h:354
TList * fList
Definition: TGFrame.h:351
virtual void SetEditDisabled(UInt_t on=1)
Set edit disable flag for this frame and subframes.
Definition: TGFrame.cxx:1004
static TGLayoutHints * fgDefaultHints
Definition: TGFrame.h:356
virtual void ActivateItem(TGFrameElement *el)
Activate item.
Definition: TGCanvas.cxx:696
TTimer * fScrollTimer
Definition: TGCanvas.h:60
virtual void ClearViewPort()
Clear view port and redraw full content.
Definition: TGCanvas.cxx:886
const TGWindow * fMsgWindow
Definition: TGCanvas.h:52
Bool_t fScrolling
Definition: TGCanvas.h:69
virtual void DoRedraw()
Redraw content of container in the viewport region.
Definition: TGCanvas.cxx:795
virtual TGDimension GetPageDimension() const
Returns page dimension.
Definition: TGCanvas.cxx:746
virtual void Layout()
Layout container entries.
Definition: TGCanvas.cxx:417
TGViewPort * fViewPort
Definition: TGCanvas.h:50
virtual Bool_t HandleDoubleClick(Event_t *event)
Handle double click mouse event.
Definition: TGCanvas.cxx:1093
virtual void DoubleClicked(TGFrame *f, Int_t btn)
Emit DoubleClicked() signal.
Definition: TGCanvas.cxx:533
virtual TGPosition GetPagePosition() const
Returns page position.
Definition: TGCanvas.cxx:732
TGFrameElement * fLastActiveEl
Definition: TGCanvas.h:53
UInt_t fHeight
Definition: TGDimension.h:30
Definition: TGFont.h:149
FontStruct_t GetFontStruct() const
Definition: TGFont.h:193
TGLayoutHints * fLayout
Definition: TGLayout.h:121
Int_t fState
Definition: TGLayout.h:120
TGFrame * fFrame
Definition: TGLayout.h:119
void AddInput(UInt_t emask)
Add events specified in the emask to the events the frame should handle.
Definition: TGFrame.cxx:321
virtual void DoRedraw()
Redraw the frame.
Definition: TGFrame.cxx:412
static const TGGC & GetBlackGC()
Get black graphics context.
Definition: TGFrame.cxx:717
UInt_t fOptions
Definition: TGFrame.h:141
void RemoveInput(UInt_t emask)
Remove events specified in emask from the events the frame should handle.
Definition: TGFrame.cxx:330
static Pixel_t GetWhitePixel()
Get white pixel value.
Definition: TGFrame.cxx:691
UInt_t fHeight
Definition: TGFrame.h:135
virtual UInt_t GetDefaultWidth() const
Definition: TGFrame.h:237
virtual UInt_t GetDefaultHeight() const
Definition: TGFrame.h:238
virtual void DrawBorder()
Draw frame border.
Definition: TGFrame.cxx:403
Int_t fBorderWidth
Definition: TGFrame.h:140
virtual void SavePrimitive(std::ostream &out, Option_t *option="")
Save a frame widget as a C++ statement(s) on output stream out.
Definition: TGFrame.cxx:3187
static Pixel_t fgDefaultSelectedBackground
Definition: TGFrame.h:149
virtual void Activate(Bool_t)
Definition: TGFrame.h:257
virtual Pixel_t GetForeground() const
Return frame foreground color.
Definition: TGFrame.cxx:285
static const TGGC & GetHilightGC()
Get highlight color graphics context.
Definition: TGFrame.cxx:737
virtual void SendMessage(const TGWindow *w, Long_t msg, Long_t parm1, Long_t parm2)
Send message (i.e.
Definition: TGFrame.cxx:627
virtual UInt_t GetOptions() const
Definition: TGFrame.h:244
TString GetOptionString() const
Returns a frame option string - used in SavePrimitive().
Definition: TGFrame.cxx:2460
static const TGGC & GetShadowGC()
Get shadow color graphics context.
Definition: TGFrame.cxx:747
virtual void Resize(UInt_t w=0, UInt_t h=0)
Resize the frame.
Definition: TGFrame.cxx:587
UInt_t fWidth
Definition: TGFrame.h:134
UInt_t GetHeight() const
Definition: TGFrame.h:272
virtual void Layout()
Definition: TGFrame.h:246
virtual void MoveResize(Int_t x, Int_t y, UInt_t w=0, UInt_t h=0)
Move and/or resize the frame.
Definition: TGFrame.cxx:611
virtual void SetWidth(UInt_t w)
Definition: TGFrame.h:293
virtual void MapWindow()
Definition: TGFrame.h:251
static Pixel_t fgWhitePixel
Definition: TGFrame.h:150
UInt_t GetWidth() const
Definition: TGFrame.h:271
void SaveUserColor(std::ostream &out, Option_t *)
Save a user color in a C++ macro file - used in SavePrimitive().
Definition: TGFrame.cxx:2433
virtual void SetHeight(UInt_t h)
Definition: TGFrame.h:294
Pixel_t fBackground
Definition: TGFrame.h:142
static const TGGC & GetBckgndGC()
Get background color graphics context.
Definition: TGFrame.cxx:757
virtual void UnmapWindow()
Definition: TGFrame.h:253
Definition: TGGC.h:31
GContext_t GetGC() const
Definition: TGGC.h:50
void SetLineWidth(Int_t v)
Set line width.
Definition: TGGC.cxx:298
void SetCapStyle(Int_t v)
Set cap style (kCapNotLast, kCapButt, kCapRound, kCapProjecting).
Definition: TGGC.cxx:320
void SetDashList(const char v[], Int_t len)
Set dash pattern. First use SetDashOffset() if not 0.
Definition: TGGC.cxx:486
void SetLineStyle(Int_t v)
Set line style (kLineSolid, kLineOnOffDash, kLineDoubleDash).
Definition: TGGC.cxx:309
virtual void DoRedraw()
Redraw icon & text listbox entry.
Definition: TGListBox.cxx:425
virtual void SetPicture(const TGPicture *pic=0)
Change the icon of listbox entry containing icon & text.
Definition: TGListBox.cxx:433
virtual ~TGIconLBEntry()
Delete icon & text listbox entry.
Definition: TGListBox.cxx:396
TGIconLBEntry(const TGIconLBEntry &)
virtual void Update(TGLBEntry *e)
Update icon & text listbox entry.
Definition: TGListBox.cxx:404
const TGPicture * fPicture
Definition: TGListBox.h:191
virtual void DrawCopy(Handle_t id, Int_t x, Int_t y)
Draw copy on window/pixmap.
Definition: TGListBox.cxx:412
virtual void RemoveAll()
Remove all entries in this container.
Definition: TGListBox.cxx:663
Bool_t fMultiSelect
Definition: TGListBox.h:234
virtual Bool_t GetSelection(Int_t id)
Returns kTrue if entry id is selected.
Definition: TGListBox.cxx:737
virtual void Layout()
Layout container.
Definition: TGListBox.cxx:507
virtual void SetListBox(TGListBox *lb)
Definition: TGListBox.h:256
virtual void OnAutoScroll()
Autoscroll while close to & beyond The Wall.
Definition: TGListBox.cxx:1024
TGLBContainer(const TGLBContainer &)
Int_t fChangeStatus
Definition: TGListBox.h:235
virtual Int_t GetSelected() const
Returns id of selected entry.
Definition: TGListBox.cxx:728
virtual void ActivateItem(TGFrameElement *el)
Activate item.
Definition: TGListBox.cxx:1078
virtual Bool_t GetMultipleSelections() const
Definition: TGListBox.h:275
virtual ~TGLBContainer()
Delete the listbox container.
Definition: TGListBox.cxx:499
virtual Bool_t HandleMotion(Event_t *event)
Handle mouse motion event in listbox container.
Definition: TGListBox.cxx:944
virtual TGLBEntry * Select(Int_t id, Bool_t sel)
Select / deselect the entry with the specified id.
Definition: TGListBox.cxx:697
TGLBEntry * fLastActive
Definition: TGListBox.h:232
virtual void RemoveEntries(Int_t from_ID, Int_t to_ID)
Remove entries from from_ID to to_ID (including).
Definition: TGListBox.cxx:637
virtual void Associate(const TGWindow *w)
Definition: TGListBox.h:255
TGListBox * fListBox
Definition: TGListBox.h:233
virtual void AddEntry(TGLBEntry *lbe, TGLayoutHints *lhints)
Add listbox entry with hints to container.
Definition: TGListBox.cxx:525
virtual TGVScrollBar * GetVScrollbar() const
Return a pointer to vertical scroll bar.
Definition: TGListBox.cxx:793
virtual Int_t GetPos(Int_t id)
Returns the position in the list box of the entry id.
Definition: TGListBox.cxx:1089
virtual void AddEntrySort(TGLBEntry *lbe, TGLayoutHints *lhints)
Insert listbox entry before the list box entry with a higher id.
Definition: TGListBox.cxx:576
virtual void InsertEntry(TGLBEntry *lbe, TGLayoutHints *lhints, Int_t afterID)
Insert listbox entry after specified entry with id afterID.
Definition: TGListBox.cxx:540
virtual void SetVsbPosition(Int_t newPos)
Set new vertical scroll bar position.
Definition: TGListBox.cxx:801
virtual void RemoveEntry(Int_t id)
Remove the entry with specified id from the listbox container.
Definition: TGListBox.cxx:609
virtual void GetSelectedEntries(TList *selected)
Adds all selected entries (TGLBEntry) of the list box into the list selected.
Definition: TGListBox.cxx:756
virtual void DoRedraw()
redraw
Definition: TGListBox.cxx:516
virtual void SetMultipleSelections(Bool_t multi)
Enables and disables multiple selections of entries.
Definition: TGListBox.cxx:773
virtual Bool_t HandleButton(Event_t *event)
Handle mouse button event in the listbox container.
Definition: TGListBox.cxx:813
virtual Bool_t HandleDoubleClick(Event_t *event)
Handle double click mouse event in the listbox container.
Definition: TGListBox.cxx:926
Pixel_t fBkcolor
Definition: TGListBox.h:56
virtual void SetBackgroundColor(Pixel_t col)
Set background color (override from TGWindow base class).
Definition: TGListBox.h:70
Int_t fEntryId
Definition: TGListBox.h:55
virtual void Activate(Bool_t a)
Toggle active state of listbox entry.
Definition: TGListBox.cxx:78
virtual void Toggle()
Toggle active state of listbox entry.
Definition: TGListBox.cxx:88
Int_t EntryId() const
Definition: TGListBox.h:68
Bool_t fActive
Definition: TGListBox.h:57
virtual void DoRedraw()
Redraw the frame.
Definition: TGListBox.h:59
TGLBEntry(const TGWindow *p=0, Int_t id=-1, UInt_t options=kHorizontalFrame, Pixel_t back=GetWhitePixel())
Base class entry constructor.
Definition: TGListBox.cxx:64
Style_t fLineStyle
Definition: TGListBox.h:150
TGGC * fLineGC
Definition: TGListBox.h:152
virtual void DoRedraw()
Redraw line style listbox entry.
Definition: TGListBox.cxx:351
UInt_t fLineLength
Definition: TGListBox.h:151
TGLineLBEntry(const TGLineLBEntry &)
UInt_t fLineWidth
Definition: TGListBox.h:149
virtual ~TGLineLBEntry()
Delete line style listbox entry.
Definition: TGListBox.cxx:251
virtual void SetLineWidth(Int_t width)
Set or change line witdh in an entry.
Definition: TGListBox.cxx:324
virtual void DrawCopy(Handle_t id, Int_t x, Int_t y)
Draw copy on window/pixmap.
Definition: TGListBox.cxx:333
virtual void SetLineStyle(Style_t style)
Set the line style corresponding to the TPad line styles.
Definition: TGListBox.cxx:271
virtual void Update(TGLBEntry *e)
Update line style listbox entry.
Definition: TGListBox.cxx:259
virtual void InitListBox()
Initiate the internal classes of a list box.
Definition: TGListBox.cxx:1151
Bool_t fIntegralHeight
Definition: TGListBox.h:297
virtual void AddEntrySort(TGString *s, Int_t id)
Add entry with specified string and id to listbox sorted by increasing id.
Definition: TGListBox.cxx:1248
virtual ~TGListBox()
Delete a listbox widget.
Definition: TGListBox.cxx:1139
virtual void SortByName(Bool_t ascend=kTRUE)
Sort entries by name.
Definition: TGListBox.cxx:1513
virtual void Resize(UInt_t w, UInt_t h)
Resize the listbox widget.
Definition: TGListBox.cxx:1419
virtual TGVScrollBar * GetVScrollbar() const
Definition: TGListBox.h:338
TGViewPort * fVport
Definition: TGListBox.h:299
UInt_t fItemVsize
Definition: TGListBox.h:296
virtual Int_t GetNumberOfEntries() const
Definition: TGListBox.h:331
TGLBContainer * fLbc
Definition: TGListBox.h:298
virtual TGDimension GetDefaultSize() const
Return default size of listbox widget.
Definition: TGListBox.cxx:1444
virtual void DrawBorder()
Draw borders of the list box widget.
Definition: TGListBox.cxx:1184
virtual TGLBEntry * GetSelectedEntry() const
Definition: TGListBox.h:356
virtual void RemoveEntry(Int_t id=-1)
remove entry with id.
Definition: TGListBox.cxx:1326
TGListBox(const TGListBox &)
virtual void NewEntry(const char *s="Entry")
method used to add entry via context menu
Definition: TGListBox.cxx:1308
virtual Int_t GetSelected() const
Return id of selected listbox item.
Definition: TGListBox.cxx:1523
virtual void SetTopEntry(Int_t id=-1)
Scroll the entry with id to the top of the listbox.
Definition: TGListBox.cxx:1395
virtual void AddEntry(TGString *s, Int_t id)
Add entry with specified string and id to listbox.
Definition: TGListBox.cxx:1211
virtual void DoubleClicked(Int_t widgetId, Int_t id)
Emit DoubleClicked signal with list box id and entry id.
Definition: TGListBox.cxx:1630
virtual void InsertEntry(TGString *s, Int_t id, Int_t afterID)
Insert entry with specified string and id behind the entry with afterID.
Definition: TGListBox.cxx:1286
virtual void MoveResize(Int_t x, Int_t y, UInt_t w, UInt_t h)
Move and resize the listbox widget.
Definition: TGListBox.cxx:1432
virtual void RemoveAll()
Remove all entries.
Definition: TGListBox.cxx:1352
virtual void SelectionChanged()
Definition: TGListBox.h:368
virtual Bool_t GetMultipleSelections() const
Definition: TGListBox.h:329
void SetContainer(TGFrame *f)
Definition: TGListBox.h:302
TGVScrollBar * fVScrollbar
Definition: TGListBox.h:300
virtual void ChangeBackground(Pixel_t back)
Change background to all entries.
Definition: TGListBox.cxx:1541
virtual TGLBEntry * GetEntry(Int_t id) const
Returns list box entry with specified id.
Definition: TGListBox.cxx:1380
virtual Bool_t ProcessMessage(Long_t msg, Long_t parm1, Long_t parm2)
Process messages generated by the listbox container and forward messages to the listbox message handl...
Definition: TGListBox.cxx:1559
virtual TGViewPort * GetViewPort() const
Definition: TGListBox.h:336
virtual TGFrame * GetContainer() const
Definition: TGListBox.h:335
virtual void SavePrimitive(std::ostream &out, Option_t *option="")
Save a list box widget as a C++ statement(s) on output stream out.
Definition: TGListBox.cxx:1658
virtual void Layout()
Layout the listbox components.
Definition: TGListBox.cxx:1460
virtual void GetSelectedEntries(TList *selected)
Adds all selected entries (TGLBEntry) of the list box into the list selected.
Definition: TGListBox.cxx:1533
virtual void RemoveEntries(Int_t from_ID, Int_t to_ID)
Remove a range of entries defined by from_ID and to_ID.
Definition: TGListBox.cxx:1361
virtual TGLBEntry * FindEntry(const char *s) const
Find entry by name.
Definition: TGListBox.cxx:1643
virtual void Selected(Int_t widgetId, Int_t id)
Emit Selected signal with list box id and entry id.
Definition: TGListBox.cxx:1617
TGClient * fClient
Definition: TGObject.h:37
Handle_t fId
Definition: TGObject.h:36
UInt_t GetHeight() const
Definition: TGPicture.h:64
void Draw(Option_t *="")
Default Draw method for all objects.
Definition: TGPicture.h:57
UInt_t GetWidth() const
Definition: TGPicture.h:63
Int_t fY
Definition: TGDimension.h:48
Int_t fX
Definition: TGDimension.h:47
Pixel_t GetBlackColor() const
Pixel_t GetSelectedFgndColor() const
virtual Int_t GetPosition() const
Definition: TGScrollBar.h:132
virtual void MoveResize(Int_t x, Int_t y, UInt_t w=0, UInt_t h=0)
Move and/or resize the frame.
Definition: TGScrollBar.h:136
Int_t GetLength() const
Definition: TGString.h:39
const char * GetString() const
Definition: TGString.h:40
virtual void Draw(Drawable_t id, GContext_t gc, Int_t x, Int_t y)
Draw string.
Definition: TGString.cxx:51
UInt_t fTWidth
Definition: TGListBox.h:88
Bool_t fTextChanged
Definition: TGListBox.h:90
const TGString * GetText() const
Definition: TGListBox.h:115
GContext_t fNormGC
Definition: TGListBox.h:91
static const TGFont * fgDefaultFont
Definition: TGListBox.h:96
TGTextLBEntry(const TGTextLBEntry &)
UInt_t fTHeight
Definition: TGListBox.h:89
TGString * fText
Definition: TGListBox.h:87
virtual void SavePrimitive(std::ostream &out, Option_t *="")
Save a list box entry widget as a C++ statement(s) on output stream out.
Definition: TGListBox.cxx:1700
FontStruct_t fFontStruct
Definition: TGListBox.h:92
virtual const char * GetTitle() const
Returns title of object.
Definition: TGListBox.h:117
static FontStruct_t GetDefaultFontStruct()
Return default font structure in use for a text listbox entry.
Definition: TGListBox.cxx:189
virtual ~TGTextLBEntry()
Delete text listbox entry.
Definition: TGListBox.cxx:130
virtual void Update(TGLBEntry *e)
Definition: TGListBox.h:121
static const TGGC & GetDefaultGC()
Return default graphics context in use for a text listbox entry.
Definition: TGListBox.cxx:199
virtual void DoRedraw()
Redraw text listbox entry.
Definition: TGListBox.cxx:162
static TGGC * fgDefaultGC
Definition: TGListBox.h:97
virtual void DrawCopy(Handle_t id, Int_t x, Int_t y)
Draw text listbox entry on window/pixmap.
Definition: TGListBox.cxx:138
void SetText(TGString *new_text)
Set or change text in text entry.
Definition: TGListBox.cxx:170
virtual void SetPosition(Int_t pos)
Set logical slider position of vertical scrollbar.
virtual void SetRange(Int_t range, Int_t page_size)
Set range of vertical scrollbar.
TGFrame * GetContainer() const
Definition: TGCanvas.h:183
virtual void SetVPos(Int_t ypos)
Moves content of container frame in vertical direction.
Definition: TGCanvas.cxx:224
Int_t fWidgetId
Definition: TGWidget.h:58
virtual void Associate(const TGWindow *w)
Definition: TGWidget.h:84
const TGWindow * fMsgWindow
Definition: TGWidget.h:60
virtual void SetWindowName(const char *name=0)
Set window name.
Definition: TGWindow.cxx:118
virtual const char * GetName() const
Return unique name, used in SavePrimitive methods.
Definition: TGWindow.cxx:221
virtual void SetEditDisabled(UInt_t on=kEditDisable)
Definition: TGWindow.h:117
const TGWindow * fParent
Definition: TGWindow.h:37
@ kEditDisableLayout
Definition: TGWindow.h:62
@ kEditDisableBtnEnable
Definition: TGWindow.h:66
@ kEditDisableGrab
Definition: TGWindow.h:61
@ kEditDisable
Definition: TGWindow.h:59
@ kEditDisableKeyEnable
Definition: TGWindow.h:67
const TGWindow * GetParent() const
Definition: TGWindow.h:85
virtual Bool_t IsMapped()
Returns kTRUE if window is mapped on screen, kFALSE otherwise.
Definition: TGWindow.cxx:180
UInt_t fEditDisabled
Definition: TGWindow.h:41
A doubly linked list.
Definition: TList.h:44
virtual void Add(TObject *obj)
Definition: TList.h:87
virtual TObject * After(const TObject *obj) const
Returns the object after object obj.
Definition: TList.cxx:327
virtual TObject * Remove(TObject *obj)
Remove object from the list.
Definition: TList.cxx:819
virtual void AddFirst(TObject *obj)
Add object at the beginning of the list.
Definition: TList.cxx:97
virtual void AddAfter(const TObject *after, TObject *obj)
Insert object after object after in the list.
Definition: TList.cxx:247
virtual void AddBefore(const TObject *before, TObject *obj)
Insert object before object before in the list.
Definition: TList.cxx:193
virtual TObject * First() const
Return the first object in the list. Returns 0 when list is empty.
Definition: TList.cxx:656
virtual void Sort(Bool_t order=kSortAscending)
Sort linked list.
Definition: TList.cxx:934
Mother of all ROOT objects.
Definition: TObject.h:37
virtual Bool_t IsSortable() const
Definition: TObject.h:131
virtual void Warning(const char *method, const char *msgfmt,...) const
Issue warning message.
Definition: TObject.cxx:866
virtual Bool_t InheritsFrom(const char *classname) const
Returns kTRUE if object inherits from class "classname".
Definition: TObject.cxx:443
virtual const char * GetTitle() const
Returns title of object.
Definition: TObject.cxx:401
virtual Int_t Compare(const TObject *obj) const
Compare abstract method.
Definition: TObject.cxx:159
void Emit(const char *signal, const T &arg)
Activate signal with single parameter.
Definition: TQObject.h:164
void AddReference()
Definition: TRefCnt.h:40
Basic string class.
Definition: TString.h:131
const char * Data() const
Definition: TString.h:364
TString & ReplaceAll(const TString &s1, const TString &s2)
Definition: TString.h:687
virtual TTime Now()
Get current time in milliseconds since 0:00 Jan 1 1995.
Definition: TSystem.cxx:472
virtual void AddTimer(TTimer *t)
Add timer to list of system timers.
Definition: TSystem.cxx:480
virtual TTimer * RemoveTimer(TTimer *t)
Remove timer from list of system timers.
Definition: TSystem.cxx:490
void Reset()
Reset the timer.
Definition: TTimer.cxx:157
TText * text
Double_t y[n]
Definition: legend1.C:17
Double_t x[n]
Definition: legend1.C:17
TF1 * f1
Definition: legend1.C:11
static constexpr double s
Short_t Max(Short_t a, Short_t b)
Definition: TMathBase.h:212
Double_t Ceil(Double_t x)
Definition: TMath.h:683
EGEventType fType
Definition: GuiTypes.h:174
Int_t fY
Definition: GuiTypes.h:177
Int_t fXRoot
Definition: GuiTypes.h:178
UInt_t fState
Definition: GuiTypes.h:180
Int_t fYRoot
Definition: GuiTypes.h:178
Long_t fUser[5]
Definition: GuiTypes.h:186
UInt_t fCode
Definition: GuiTypes.h:179
Int_t fDashOffset
Definition: GuiTypes.h:247
Int_t fLineWidth
Definition: GuiTypes.h:228
Mask_t fMask
Definition: GuiTypes.h:250
Int_t fLineStyle
Definition: GuiTypes.h:229
Char_t fDashes[8]
Definition: GuiTypes.h:248
Int_t fFillStyle
Definition: GuiTypes.h:233
Int_t fDashLen
Definition: GuiTypes.h:249
TCanvas * style()
Definition: style.C:1
auto * l
Definition: textangle.C:4
auto * a
Definition: textangle.C:12
auto * t1
Definition: textangle.C:20