Logo ROOT  
Reference Guide
 
Loading...
Searching...
No Matches
TVirtualX.cxx
Go to the documentation of this file.
1// @(#)root/base:$Id$
2// Author: Fons Rademakers 3/12/95
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\defgroup GraphicsBackends Graphics' Backends
14\ingroup Graphics
15Graphics' Backends interface classes.
16Graphics classes interfacing ROOT graphics with the low level
17native graphics backends(s) like X11, Cocoa, Win32 etc...
18These classes are not meant to be used directly by ROOT users.
19*/
20
21/** \class TVirtualX
22\ingroup GraphicsBackends
23\ingroup Base
24Semi-Abstract base class defining a generic interface to the underlying, low
25level, native graphics backend (X11, Win32, MacOS, OpenGL...).
26An instance of TVirtualX itself defines a batch interface to the graphics system.
27*/
28
29#include "TVirtualX.h"
30#include "TString.h"
31#include "TPoint.h"
32
33
37
38
39TVirtualX *gGXBatch; //Global pointer to batch graphics interface
40TVirtualX* (*gPtr2VirtualX)() = nullptr; // returns pointer to global object
41
42
43
44
45////////////////////////////////////////////////////////////////////////////////
46/// Ctor of ABC
47
48TVirtualX::TVirtualX(const char *name, const char *title) : TNamed(name, title),
49 TAttLine(1,1,1),TAttFill(1,1),TAttText(11,0,1,62,0.01), TAttMarker(1,1,1),
50 fDrawMode()
51{
52}
53
54////////////////////////////////////////////////////////////////////////////////
55/// Returns gVirtualX global
56
58{
59 static TVirtualX *instance = nullptr;
61 return instance;
62}
63
64////////////////////////////////////////////////////////////////////////////////
65/// The WindowAttributes_t structure is set to default.
66
68{
69 attr.fX = attr.fY = 0;
70 attr.fWidth = attr.fHeight = 0;
71 attr.fVisual = nullptr;
72 attr.fMapState = kIsUnmapped;
73 attr.fScreen = nullptr;
74}
75
76////////////////////////////////////////////////////////////////////////////////
77/// Looks up the string name of a color "cname" with respect to the screen
78/// associated with the specified colormap. It returns the exact color value.
79/// If the color name is not in the Host Portable Character Encoding,
80/// the result is implementation dependent.
81///
82/// \param [in] cmap the colormap
83/// \param [in] cname the color name string; use of uppercase or lowercase
84/// does not matter
85/// \param [in] color returns the exact color value for later use
86///
87/// The ColorStruct_t structure is set to default. Let system think we
88/// could parse color.
89
90Bool_t TVirtualX::ParseColor(Colormap_t /*cmap*/, const char * /*cname*/,
91 ColorStruct_t &color)
92{
93 color.fPixel = 0;
94 color.fRed = 0;
95 color.fGreen = 0;
96 color.fBlue = 0;
97 color.fMask = kDoRed | kDoGreen | kDoBlue;
98
99 return kTRUE;
100}
101
102////////////////////////////////////////////////////////////////////////////////
103/// Allocates a read-only colormap entry corresponding to the closest RGB
104/// value supported by the hardware. If no cell could be allocated it
105/// returns kFALSE, otherwise kTRUE.
106///
107/// The pixel value is set to default. Let system think we could allocate
108/// color.
109///
110/// \param [in] cmap the colormap
111/// \param [in] color specifies and returns the values actually used in the cmap
112
114{
115 color.fPixel = 0;
116 return kTRUE;
117}
118
119////////////////////////////////////////////////////////////////////////////////
120/// Returns the current RGB value for the pixel in the "color" structure
121///
122/// The color components are set to default.
123///
124/// \param [in] cmap the colormap
125/// \param [in] color specifies and returns the RGB values for the pixel specified
126/// in the structure
127
129{
130 color.fRed = color.fGreen = color.fBlue = 0;
131}
132
133////////////////////////////////////////////////////////////////////////////////
134/// The "event" is set to default event.
135/// This method however, should never be called.
136
138{
139 event.fType = kButtonPress;
140 event.fWindow = 0;
141 event.fTime = 0;
142 event.fX = 0;
143 event.fY = 0;
144 event.fXRoot = 0;
145 event.fYRoot = 0;
146 event.fState = 0;
147 event.fCode = 0;
148 event.fWidth = 0;
149 event.fHeight = 0;
150 event.fCount = 0;
151}
152
153////////////////////////////////////////////////////////////////////////////////
154/// Gets contents of the paste buffer "atom" into the string "text".
155/// (nchar = number of characters) If "del" is true deletes the paste
156/// buffer afterwards.
157
159 Int_t &nchar, Bool_t /*del*/)
160{
161 text = "";
162 nchar = 0;
163}
164
165////////////////////////////////////////////////////////////////////////////////
166/// Initializes the X system. Returns kFALSE in case of failure.
167/// It is implementation dependent.
168
169Bool_t TVirtualX::Init(void * /*display*/)
170{
171 return kFALSE;
172}
173
174////////////////////////////////////////////////////////////////////////////////
175/// Clears the entire area of the current window.
176
178{
179}
180
181////////////////////////////////////////////////////////////////////////////////
182/// Deletes current window.
183
185{
186}
187
188////////////////////////////////////////////////////////////////////////////////
189/// Deletes current pixmap.
190
192{
193}
194
195////////////////////////////////////////////////////////////////////////////////
196/// Copies the pixmap "wid" at the position [xpos,ypos] in the current window.
197
198void TVirtualX::CopyPixmap(Int_t /*wid*/, Int_t /*xpos*/, Int_t /*ypos*/)
199{
200}
201
202////////////////////////////////////////////////////////////////////////////////
203///On a HiDPI resolution it can be > 1., this means glViewport should use
204///scaled width and height.
205
210
211////////////////////////////////////////////////////////////////////////////////
212/// Creates OpenGL context for window "wid"
213
215{
216}
217
218////////////////////////////////////////////////////////////////////////////////
219/// Deletes OpenGL context for window "wid"
220
222{
223}
224
225////////////////////////////////////////////////////////////////////////////////
226///Create window with special pixel format. Noop everywhere except Cocoa.
227
228Window_t TVirtualX::CreateOpenGLWindow(Window_t /*parentID*/, UInt_t /*width*/, UInt_t /*height*/, const std::vector<std::pair<UInt_t, Int_t> > &/*format*/)
229{
230 return Window_t();
231}
232
233////////////////////////////////////////////////////////////////////////////////
234/// Creates OpenGL context for window "windowID".
235
237{
238 return Handle_t();
239}
240
241////////////////////////////////////////////////////////////////////////////////
242/// Makes context ctx current OpenGL context.
243
245{
246 return kFALSE;
247}
248
249////////////////////////////////////////////////////////////////////////////////
250/// Asks OpenGL subsystem about the current OpenGL context.
251
256
257////////////////////////////////////////////////////////////////////////////////
258/// Flushes OpenGL buffer.
259
263
264////////////////////////////////////////////////////////////////////////////////
265/// Draws a box between [x1,y1] and [x2,y2] according to the "mode".
266///
267/// \param [in] x1,y1 left down corner
268/// \param [in] x2,y2 right up corner
269/// \param [in] mode drawing mode:
270/// - mode = 0 hollow (kHollow)
271/// - mode = 1 solid (kSolid)
272
273void TVirtualX::DrawBox(Int_t /*x1*/, Int_t /*y1*/, Int_t /*x2*/, Int_t /*y2*/,
274 EBoxMode /*mode*/)
275{
276}
277
278////////////////////////////////////////////////////////////////////////////////
279/// Draws a cell array. The drawing is done with the pixel precision
280/// if (x2-x1)/nx (or y) is not a exact pixel number the position of
281/// the top right corner may be wrong.
282///
283/// \param [in] x1,y1 left down corner
284/// \param [in] x2,y2 right up corner
285/// \param [in] nx,ny array size
286/// \param [in] ic array
287
289 Int_t /*x2*/, Int_t /*y2*/,
290 Int_t /*nx*/, Int_t /*ny*/, Int_t * /*ic*/)
291{
292}
293
294////////////////////////////////////////////////////////////////////////////////
295/// Fills area described by the polygon.
296///
297/// \param [in] n number of points
298/// \param [in] xy list of points. xy(2,n)
299
301{
302}
303
304////////////////////////////////////////////////////////////////////////////////
305/// Draws a line.
306///
307/// \param [in] x1,y1 begin of line
308/// \param [in] x2,y2 end of line
309
310void TVirtualX::DrawLine(Int_t /*x1*/, Int_t /*y1*/, Int_t /*x2*/, Int_t /*y2*/)
311{
312}
313
314////////////////////////////////////////////////////////////////////////////////
315/// Draws a line through all points in the list.
316///
317/// \param [in] n number of points
318/// \param [in] xy list of points
319
321{
322}
323
324////////////////////////////////////////////////////////////////////////////////
325/// Draws N segments between provided points
326///
327/// \param [in] n number of segemtns
328/// \param [in] xy list of points, size 2*n
329
331{
332 for(Int_t i = 0; i < 2*n; i += 2)
333 DrawPolyLine(2, &xy[i]);
334}
335
336
337////////////////////////////////////////////////////////////////////////////////
338/// Draws "n" markers with the current attributes at position [x,y].
339///
340/// \param [in] n number of markers to draw
341/// \param [in] xy an array of x,y marker coordinates
342
344{
345}
346
347////////////////////////////////////////////////////////////////////////////////
348/// Draws a text string using current font.
349///
350/// \param [in] x,y text position
351/// \param [in] angle text angle
352/// \param [in] mgn magnification factor
353/// \param [in] text text string
354/// \param [in] mode drawing mode:
355/// - mode = 0 the background is not drawn (kClear)
356/// - mode = 1 the background is drawn (kOpaque)
357
358void TVirtualX::DrawText(Int_t /*x*/, Int_t /*y*/, Float_t /*angle*/,
359 Float_t /*mgn*/, const char * /*text*/,
360 ETextMode /*mode*/)
361{
362}
363
364////////////////////////////////////////////////////////////////////////////////
365/// Draws a text string using current font.
366///
367/// \param [in] x,y text position
368/// \param [in] angle text angle
369/// \param [in] mgn magnification factor
370/// \param [in] text text string
371/// \param [in] mode drawing mode:
372/// - mode = 0 the background is not drawn (kClear)
373/// - mode = 1 the background is drawn (kOpaque)
374
375void TVirtualX::DrawText(Int_t /*x*/, Int_t /*y*/, Float_t /*angle*/,
376 Float_t /*mgn*/, const wchar_t * /*text*/,
377 ETextMode /*mode*/)
378{
379}
380
381////////////////////////////////////////////////////////////////////////////////
382/// Get window drawing context
383/// Should remain valid until window exists
384
386{
387 return (WinContext_t) 0;
388}
389
390////////////////////////////////////////////////////////////////////////////////
391/// Set fill attributes for specified window
392
394{
395 SetFillColor(att.GetFillColor());
396 SetFillStyle(att.GetFillStyle());
397}
398
399////////////////////////////////////////////////////////////////////////////////
400/// Set line attributes for specified window
401
403{
404 SetLineColor(att.GetLineColor());
405 SetLineStyle(att.GetLineStyle());
406 SetLineWidth(att.GetLineWidth());
407}
408
409////////////////////////////////////////////////////////////////////////////////
410/// Set marker attributes for specified window
411
413{
414 SetMarkerColor(att.GetMarkerColor());
415 SetMarkerSize(att.GetMarkerSize());
416 SetMarkerStyle(att.GetMarkerStyle());
417}
418
419////////////////////////////////////////////////////////////////////////////////
420/// Set text attributes for specified window
421
423{
424 SetTextAlign(att.GetTextAlign());
425 SetTextAngle(att.GetTextAngle());
426 SetTextColor(att.GetTextColor());
427 SetTextSize(att.GetTextSize());
428 SetTextFont(att.GetTextFont());
429}
430
431////////////////////////////////////////////////////////////////////////////////
432/// Set window draw mode
433
438
439////////////////////////////////////////////////////////////////////////////////
440/// Returns window draw mode
441
446
447////////////////////////////////////////////////////////////////////////////////
448/// Clear specified window
449
451{
452 ClearWindow();
453}
454
455////////////////////////////////////////////////////////////////////////////////
456/// Update specified window
457
462
463////////////////////////////////////////////////////////////////////////////////
464/// Set opactity for specified window
465
470
471////////////////////////////////////////////////////////////////////////////////
472/// Copy pixmap to specified window
473
478
479////////////////////////////////////////////////////////////////////////////////
480/// Draw box on specified window
481
486
487////////////////////////////////////////////////////////////////////////////////
488/// Draw fill area on specified window
489
491{
492 DrawFillArea(n, xy);
493}
494
495////////////////////////////////////////////////////////////////////////////////
496/// Draw line on specified window
497
499{
500 DrawLine(x1, y1, x2, y2);
501}
502
503////////////////////////////////////////////////////////////////////////////////
504/// Draw poly line on specified window
505
507{
508 DrawPolyLine(n, xy);
509}
510
511////////////////////////////////////////////////////////////////////////////////
512/// Draw line segments on specified window
513
518
519////////////////////////////////////////////////////////////////////////////////
520/// Draw poly marker on specified window
521
526
527////////////////////////////////////////////////////////////////////////////////
528/// Draw text on specified window
529
531{
532 DrawText(x, y, angle, mgn, text, mode);
533}
534
535////////////////////////////////////////////////////////////////////////////////
536/// Draw wtext on specified window
537
539{
540 DrawText(x, y, angle, mgn, text, mode);
541}
542
543////////////////////////////////////////////////////////////////////////////////
544/// Save specified window as GIF image
545
547{
548 return WriteGIF((char *) name);
549}
550
551////////////////////////////////////////////////////////////////////////////////
552/// Executes the command "code" coming from the other threads (Win32)
553
555{
556 return 0;
557}
558
559////////////////////////////////////////////////////////////////////////////////
560/// Queries the double buffer value for the window "wid".
561
563{
564 return 0;
565}
566
567////////////////////////////////////////////////////////////////////////////////
568/// Returns character up vector.
569
574
575////////////////////////////////////////////////////////////////////////////////
576/// Returns position and size of window "wid".
577///
578/// \param [in] wid window identifier
579/// if wid < 0 the size of the display is returned
580/// \param [in] x, y returned window position
581/// \param [in] w, h returned window size
582
584 UInt_t &w, UInt_t &h)
585{
586 x = y = 0;
587 w = h = 0;
588}
589
590////////////////////////////////////////////////////////////////////////////////
591/// Returns hostname on which the display is opened.
592
593const char *TVirtualX::DisplayName(const char *)
594{
595 return "batch";
596}
597
598////////////////////////////////////////////////////////////////////////////////
599/// Returns the current native event handle.
600
602{
603 return 0;
604}
605
606////////////////////////////////////////////////////////////////////////////////
607/// Returns pixel value associated to specified ROOT color number "cindex".
608
610{
611 return 0;
612}
613
614////////////////////////////////////////////////////////////////////////////////
615/// Returns the maximum number of planes.
616
618{
619 nplanes = 0;
620}
621
622////////////////////////////////////////////////////////////////////////////////
623/// Returns RGB values for color "index".
624
626{
627 r = g = b = 0;
628}
629
630////////////////////////////////////////////////////////////////////////////////
631/// Returns the size of the specified character string "mess".
632///
633/// \param [in] w the text width
634/// \param [in] h the text height
635/// \param [in] mess the string
636
637void TVirtualX::GetTextExtent(UInt_t &w, UInt_t &h, char * /*mess*/)
638{
639 w = h = 0;
640}
641
642////////////////////////////////////////////////////////////////////////////////
643/// Returns the size of the specified character string "mess".
644///
645/// \param [in] w the text width
646/// \param [in] h the text height
647/// \param [in] mess the string
648
649void TVirtualX::GetTextExtent(UInt_t &w, UInt_t &h, wchar_t * /*mess*/)
650{
651 w = h = 0;
652}
653
654////////////////////////////////////////////////////////////////////////////////
655/// Returns the size of the specified character string "mess" for font and size.
656
658{
659 w = h = 0;
660 return kFALSE;
661}
662
663////////////////////////////////////////////////////////////////////////////////
664/// Returns the size of the specified character string "mess" for font and size.
665
667{
668 w = h = 0;
669 return kFALSE;
670}
671
672////////////////////////////////////////////////////////////////////////////////
673/// Returns ascent/descent for specified character string "mess" with font and size.
674
675
677{
678 a = d = 0;
679 return kFALSE;
680}
681
682////////////////////////////////////////////////////////////////////////////////
683/// Returns the ascent of the current font (in pixels).
684/// The ascent of a font is the distance from the baseline
685/// to the highest position characters extend to
686
688{
689 return 0;
690}
691
692////////////////////////////////////////////////////////////////////////////////
693/// Default version is noop, but in principle what
694/// ROOT understands as ascent is text related.
695
696Int_t TVirtualX::GetFontAscent(const char * /*mess*/) const
697{
698 return GetFontAscent();
699}
700
701////////////////////////////////////////////////////////////////////////////////
702/// Returns the descent of the current font (in pixels.
703/// The descent is the distance from the base line
704/// to the lowest point characters extend to.
705
707{
708 return 0;
709}
710
711////////////////////////////////////////////////////////////////////////////////
712/// Default version is noop, but in principle what
713/// ROOT understands as descent requires a certain text.
714
715Int_t TVirtualX::GetFontDescent(const char * /*mess*/) const
716{
717 return GetFontDescent();
718}
719
720////////////////////////////////////////////////////////////////////////////////
721/// Returns the current font magnification factor
722
724{
725 return 0;
726}
727
728////////////////////////////////////////////////////////////////////////////////
729/// Returns True when TrueType fonts are used
730
732{
733 return kFALSE;
734}
735
736////////////////////////////////////////////////////////////////////////////////
737/// Returns the X11 window identifier.
738///
739/// \param [in] wid workstation identifier (input)
740
742{
743 return 0;
744}
745
746////////////////////////////////////////////////////////////////////////////////
747/// Creates a new window and return window number.
748/// Returns -1 if window initialization fails.
749
751{
752 return 0;
753}
754
755////////////////////////////////////////////////////////////////////////////////
756/// Registers a window created by Qt as a ROOT window
757///
758/// \param [in] qwid window identifier
759/// \param [in] w, h the width and height, which define the window size
760
762{
763 return 0;
764}
765
766////////////////////////////////////////////////////////////////////////////////
767/// Registers a pixmap created by TGLManager as a ROOT pixmap
768///
769/// \param [in] pixid pixmap identifier
770/// \param [in] w, h the width and height, which define the pixmap size
771
773{
774 return 0;
775}
776
777
778////////////////////////////////////////////////////////////////////////////////
779/// Removes the created by Qt window "qwid".
780
782{
783}
784
785////////////////////////////////////////////////////////////////////////////////
786/// Moves the window "wid" to the specified x and y coordinates.
787/// It does not change the window's size, raise the window, or change
788/// the mapping state of the window.
789///
790/// \param [in] wid window identifier
791/// \param [in] x, y coordinates, which define the new position of the window
792/// relative to its parent.
793
794void TVirtualX::MoveWindow(Int_t /*wid*/, Int_t /*x*/, Int_t /*y*/)
795{
796}
797
798////////////////////////////////////////////////////////////////////////////////
799/// Creates a pixmap of the width "w" and height "h" you specified.
800
802{
803 return 0;
804}
805
806////////////////////////////////////////////////////////////////////////////////
807/// Returns the pointer position.
808
810{
811 ix = iy = 0;
812}
813
814////////////////////////////////////////////////////////////////////////////////
815/// If id is NULL - loads the specified gif file at position [x0,y0] in the
816/// current window. Otherwise creates pixmap from gif file
817
818Pixmap_t TVirtualX::ReadGIF(Int_t /*x0*/, Int_t /*y0*/, const char * /*file*/,
819 Window_t /*id*/)
820{
821 return 0;
822}
823
824////////////////////////////////////////////////////////////////////////////////
825/// Requests Locator position.
826///
827/// \param [in] x,y cursor position at moment of button press (output)
828/// \param [in] ctyp cursor type (input)
829/// - ctyp = 1 tracking cross
830/// - ctyp = 2 cross-hair
831/// - ctyp = 3 rubber circle
832/// - ctyp = 4 rubber band
833/// - ctyp = 5 rubber rectangle
834///
835/// \param [in] mode input mode
836/// - mode = 0 request
837/// - mode = 1 sample
838///
839/// \return
840/// - in request mode:
841/// - 1 = left is pressed
842/// - 2 = middle is pressed
843/// - 3 = right is pressed
844/// - in sample mode:
845/// - 11 = left is released
846/// - 12 = middle is released
847/// - 13 = right is released
848/// - -1 = nothing is pressed or released
849/// - -2 = leave the window
850/// - else = keycode (keyboard is pressed)
851
853 Int_t &x, Int_t &y)
854{
855 x = y = 0;
856 return 0;
857}
858
859////////////////////////////////////////////////////////////////////////////////
860/// Requests string: text is displayed and can be edited with Emacs-like
861/// keybinding. Returns termination code (0 for ESC, 1 for RETURN)
862///
863/// \param [in] x,y position where text is displayed
864/// \param [in] text displayed text (as input), edited text (as output)
865
867{
868 if (text) *text = 0;
869 return 0;
870}
871
872////////////////////////////////////////////////////////////////////////////////
873/// Rescales the window "wid".
874///
875/// \param [in] wid window identifier
876/// \param [in] w the width
877/// \param [in] h the height
878
879void TVirtualX::RescaleWindow(Int_t /*wid*/, UInt_t /*w*/, UInt_t /*h*/)
880{
881}
882
883////////////////////////////////////////////////////////////////////////////////
884/// Resizes the specified pixmap "wid".
885///
886/// \param [in] wid window identifier
887/// \param [in] w, h the width and height which define the pixmap dimensions
888
890{
891 return 0;
892}
893
894////////////////////////////////////////////////////////////////////////////////
895/// Resizes the window "wid" if necessary.
896
898{
899}
900
901////////////////////////////////////////////////////////////////////////////////
902/// Selects the window "wid" to which subsequent output is directed.
903
905{
906}
907
908////////////////////////////////////////////////////////////////////////////////
909/// Selects the pixmap "qpixid".
910
912{
913}
914
915////////////////////////////////////////////////////////////////////////////////
916/// Sets character up vector.
917
918void TVirtualX::SetCharacterUp(Float_t /*chupx*/, Float_t /*chupy*/)
919{
920}
921
922////////////////////////////////////////////////////////////////////////////////
923/// Turns off the clipping for the window "wid".
924
926{
927}
928
929////////////////////////////////////////////////////////////////////////////////
930/// Sets clipping region for the window "wid".
931///
932/// \param [in] wid window identifier
933/// \param [in] x, y origin of clipping rectangle
934/// \param [in] w, h the clipping rectangle dimensions
935
936void TVirtualX::SetClipRegion(Int_t /*wid*/, Int_t /*x*/, Int_t /*y*/,
937 UInt_t /*w*/, UInt_t /*h*/)
938{
939}
940
941////////////////////////////////////////////////////////////////////////////////
942/// The cursor "cursor" will be used when the pointer is in the
943/// window "wid".
944
945void TVirtualX::SetCursor(Int_t /*win*/, ECursor /*cursor*/)
946{
947}
948
949////////////////////////////////////////////////////////////////////////////////
950/// Sets the double buffer on/off on the window "wid".
951///
952/// \param [in] wid window identifier.
953/// - 999 means all opened windows.
954/// \param [in] mode the on/off switch
955/// - mode = 1 double buffer is on
956/// - mode = 0 double buffer is off
957
959{
960}
961
962////////////////////////////////////////////////////////////////////////////////
963/// Turns double buffer mode off.
964
968
969////////////////////////////////////////////////////////////////////////////////
970/// Turns double buffer mode on.
971
975
976////////////////////////////////////////////////////////////////////////////////
977/// Sets the drawing mode.
978///
979/// \param [in] mode drawing mode.
980/// - mode = 1 copy
981/// - mode = 2 xor
982/// - mode = 3 invert
983/// - mode = 4 set the suitable mode for cursor echo according to the vendor
984
986{
987}
988
989////////////////////////////////////////////////////////////////////////////////
990/// Sets color index "cindex" for fill areas.
991
993{
994}
995
996////////////////////////////////////////////////////////////////////////////////
997/// Sets fill area style.
998///
999/// \param [in] style compound fill area interior style
1000/// - style = 1000 * interiorstyle + styleindex
1001
1003{
1004}
1005
1006////////////////////////////////////////////////////////////////////////////////
1007/// Sets color index "cindex" for drawing lines.
1008
1010{
1011}
1012
1013////////////////////////////////////////////////////////////////////////////////
1014/// Sets the line type.
1015///
1016/// \param [in] n length of the dash list
1017/// - n <= 0 use solid lines
1018/// - n > 0 use dashed lines described by dash(n)
1019/// e.g. n = 4,dash = (6,3,1,3) gives a dashed-dotted line
1020/// with dash length 6 and a gap of 7 between dashes
1021/// \param [in] dash dash segment lengths
1022
1023void TVirtualX::SetLineType(Int_t /*n*/, Int_t * /*dash*/)
1024{
1025}
1026
1027////////////////////////////////////////////////////////////////////////////////
1028/// Sets the line style.
1029///
1030/// \param [in] linestyle line style.
1031/// - linestyle <= 1 solid
1032/// - linestyle = 2 dashed
1033/// - linestyle = 3 dotted
1034/// - linestyle = 4 dashed-dotted
1035
1037{
1038}
1039
1040////////////////////////////////////////////////////////////////////////////////
1041/// Sets the line width.
1042///
1043/// \param [in] width the line width in pixels
1044
1046{
1047}
1048
1049////////////////////////////////////////////////////////////////////////////////
1050/// Sets color index "cindex" for markers.
1051
1053{
1054}
1055
1056////////////////////////////////////////////////////////////////////////////////
1057/// Sets marker size index.
1058///
1059/// \param [in] markersize the marker scale factor
1060
1062{
1063}
1064
1065////////////////////////////////////////////////////////////////////////////////
1066/// Sets marker style.
1067
1069{
1070}
1071
1072////////////////////////////////////////////////////////////////////////////////
1073/// Sets opacity of the current window. This image manipulation routine
1074/// works by adding to a percent amount of neutral to each pixels RGB.
1075/// Since it requires quite some additional color map entries is it
1076/// only supported on displays with more than > 8 color planes (> 256
1077/// colors).
1078
1080{
1081}
1082
1083////////////////////////////////////////////////////////////////////////////////
1084/// Sets color intensities the specified color index "cindex".
1085///
1086/// \param [in] cindex color index
1087/// \param [in] r, g, b the red, green, blue intensities between 0.0 and 1.0
1088
1089void TVirtualX::SetRGB(Int_t /*cindex*/, Float_t /*r*/, Float_t /*g*/,
1090 Float_t /*b*/)
1091{
1092}
1093
1094////////////////////////////////////////////////////////////////////////////////
1095/// Sets the text alignment.
1096///
1097/// \param [in] talign text alignment.
1098/// - talign = txalh horizontal text alignment
1099/// - talign = txalv vertical text alignment
1100
1102{
1103}
1104
1105////////////////////////////////////////////////////////////////////////////////
1106/// Sets the color index "cindex" for text.
1107
1109{
1110}
1111
1112////////////////////////////////////////////////////////////////////////////////
1113/// Sets text font to specified name "fontname".This function returns 0 if
1114/// the specified font is found, 1 if it is not.
1115///
1116/// \param [in] fontname font name
1117/// \param [in] mode loading flag
1118/// - mode = 0 search if the font exist (kCheck)
1119/// - mode = 1 search the font and load it if it exists (kLoad)
1120
1121Int_t TVirtualX::SetTextFont(char * /*fontname*/, ETextSetMode /*mode*/)
1122{
1123 return 0;
1124}
1125
1126////////////////////////////////////////////////////////////////////////////////
1127/// Sets the current text font number.
1128
1129void TVirtualX::SetTextFont(Font_t /*fontnumber*/)
1130{
1131}
1132
1133////////////////////////////////////////////////////////////////////////////////
1134/// Sets the current text magnification factor to "mgn"
1135
1137{
1138}
1139
1140////////////////////////////////////////////////////////////////////////////////
1141/// Sets the current text size to "textsize"
1142
1144{
1145}
1146
1147////////////////////////////////////////////////////////////////////////////////
1148/// Set synchronisation on or off.
1149///
1150/// \param [in] mode synchronisation on/off
1151/// - mode=1 on
1152/// - mode<>0 off
1153
1155{
1156}
1157
1158////////////////////////////////////////////////////////////////////////////////
1159/// Updates or synchronises client and server once (not permanent).
1160/// according to "mode".
1161///
1162/// \param [in] mode update mode.
1163/// - mode = 1 update
1164/// - mode = 0 sync
1165
1167{
1168}
1169
1170////////////////////////////////////////////////////////////////////////////////
1171/// Sets the pointer position.
1172///
1173/// \param [in] ix new X coordinate of pointer
1174/// \param [in] iy new Y coordinate of pointer
1175/// \param [in] id window identifier
1176///
1177/// Coordinates are relative to the origin of the window id
1178/// or to the origin of the current window if id == 0.
1179
1180void TVirtualX::Warp(Int_t /*ix*/, Int_t /*iy*/, Window_t /*id*/)
1181{
1182}
1183
1184////////////////////////////////////////////////////////////////////////////////
1185/// Writes the current window into GIF file.
1186/// Returns 1 in case of success, 0 otherwise.
1187
1189{
1190 return 0;
1191}
1192
1193////////////////////////////////////////////////////////////////////////////////
1194/// Writes the pixmap "wid" in the bitmap file "pxname".
1195///
1196/// \param [in] wid the pixmap address
1197/// \param [in] w, h the width and height of the pixmap.
1198/// \param [in] pxname the file name
1199
1200void TVirtualX::WritePixmap(Int_t /*wid*/, UInt_t /*w*/, UInt_t /*h*/,
1201 char * /*pxname*/)
1202{
1203}
1204
1205
1206//---- Methods used for GUI -----
1207////////////////////////////////////////////////////////////////////////////////
1208/// Maps the window "id" and all of its subwindows that have had map
1209/// requests. This function has no effect if the window is already mapped.
1210
1212{
1213}
1214
1215////////////////////////////////////////////////////////////////////////////////
1216/// Maps all subwindows for the specified window "id" in top-to-bottom
1217/// stacking order.
1218
1220{
1221}
1222
1223////////////////////////////////////////////////////////////////////////////////
1224/// Maps the window "id" and all of its subwindows that have had map
1225/// requests on the screen and put this window on the top of of the
1226/// stack of all windows.
1227
1229{
1230}
1231
1232////////////////////////////////////////////////////////////////////////////////
1233/// Unmaps the specified window "id". If the specified window is already
1234/// unmapped, this function has no effect. Any child window will no longer
1235/// be visible (but they are still mapped) until another map call is made
1236/// on the parent.
1237
1239{
1240}
1241
1242////////////////////////////////////////////////////////////////////////////////
1243/// Destroys the window "id" as well as all of its subwindows.
1244/// The window should never be referenced again. If the window specified
1245/// by the "id" argument is mapped, it is unmapped automatically.
1246
1248{
1249}
1250
1251////////////////////////////////////////////////////////////////////////////////
1252/// The DestroySubwindows function destroys all inferior windows of the
1253/// specified window, in bottom-to-top stacking order.
1254
1258
1259////////////////////////////////////////////////////////////////////////////////
1260/// Raises the specified window to the top of the stack so that no
1261/// sibling window obscures it.
1262
1264{
1265}
1266
1267////////////////////////////////////////////////////////////////////////////////
1268/// Lowers the specified window "id" to the bottom of the stack so
1269/// that it does not obscure any sibling windows.
1270
1272{
1273}
1274
1275////////////////////////////////////////////////////////////////////////////////
1276/// Moves the specified window to the specified x and y coordinates.
1277/// It does not change the window's size, raise the window, or change
1278/// the mapping state of the window.
1279///
1280/// \param [in] id window identifier
1281/// \param [in] x, y coordinates, which define the new position of the window
1282/// relative to its parent.
1283
1284void TVirtualX::MoveWindow(Window_t /*id*/, Int_t /*x*/, Int_t /*y*/)
1285{
1286}
1287
1288////////////////////////////////////////////////////////////////////////////////
1289/// Changes the size and location of the specified window "id" without
1290/// raising it.
1291///
1292/// \param [in] id window identifier
1293/// \param [in] x, y coordinates, which define the new position of the window
1294/// relative to its parent.
1295/// \param [in] w, h the width and height, which define the interior size of
1296/// the window
1297
1299 UInt_t /*w*/, UInt_t /*h*/)
1300{
1301}
1302
1303////////////////////////////////////////////////////////////////////////////////
1304/// Changes the width and height of the specified window "id", not
1305/// including its borders. This function does not change the window's
1306/// upper-left coordinate.
1307///
1308/// \param [in] id window identifier
1309/// \param [in] w, h the width and height, which are the interior dimensions of
1310/// the window after the call completes.
1311
1313{
1314}
1315
1316////////////////////////////////////////////////////////////////////////////////
1317/// Iconifies the window "id".
1318
1320{
1321}
1322////////////////////////////////////////////////////////////////////////////////
1323/// Notify the low level GUI layer ROOT requires "tgwindow" to be
1324/// updated
1325///
1326/// Returns kTRUE if the notification was desirable and it was sent
1327///
1328/// At the moment only Qt4 layer needs that
1329///
1330/// One needs explicitly cast the first parameter to TGWindow to make
1331/// it working in the implementation.
1332///
1333/// One needs to process the notification to confine
1334/// all paint operations within "expose" / "paint" like low level event
1335/// or equivalent
1336
1338{
1339 return kFALSE;
1340}
1341
1342////////////////////////////////////////////////////////////////////////////////
1343/// If the specified window is mapped, ReparentWindow automatically
1344/// performs an UnmapWindow request on it, removes it from its current
1345/// position in the hierarchy, and inserts it as the child of the specified
1346/// parent. The window is placed in the stacking order on top with respect
1347/// to sibling windows.
1348
1350 Int_t /*x*/, Int_t /*y*/)
1351{
1352}
1353
1354////////////////////////////////////////////////////////////////////////////////
1355/// Sets the background of the window "id" to the specified color value
1356/// "color". Changing the background does not cause the window contents
1357/// to be changed.
1358
1360{
1361}
1362
1363////////////////////////////////////////////////////////////////////////////////
1364/// Sets the background pixmap of the window "id" to the specified
1365/// pixmap "pxm".
1366
1370
1371////////////////////////////////////////////////////////////////////////////////
1372/// Creates an unmapped subwindow for a specified parent window and returns
1373/// the created window. The created window is placed on top in the stacking
1374/// order with respect to siblings. The coordinate system has the X axis
1375/// horizontal and the Y axis vertical with the origin [0,0] at the
1376/// upper-left corner. Each window and pixmap has its own coordinate system.
1377///
1378/// \param [in] parent the parent window
1379/// \param [in] x, y coordinates, the top-left outside corner of the window's
1380/// borders; relative to the inside of the parent window's borders
1381/// \param [in] w, h width and height of the created window; do not include the
1382/// created window's borders
1383/// \param [in] border the border pixel value of the window
1384/// \param [in] depth the window's depth
1385/// \param [in] clss the created window's class; can be InputOutput, InputOnly, or
1386/// CopyFromParent
1387/// \param [in] visual the visual type
1388/// \param [in] attr the structure from which the values are to be taken.
1389/// \param [in] wtype the window type
1390
1392 UInt_t /*w*/, UInt_t /*h*/,
1393 UInt_t /*border*/, Int_t /*depth*/,
1394 UInt_t /*clss*/, void * /*visual*/,
1395 SetWindowAttributes_t * /*attr*/,
1396 UInt_t /*wtype*/)
1397{
1398 return 0;
1399}
1400
1401////////////////////////////////////////////////////////////////////////////////
1402/// Opens connection to display server (if such a thing exist on the
1403/// current platform). The encoding and interpretation of the display
1404/// name.
1405///
1406/// On X11 this method returns on success the X display socket descriptor
1407/// >0, 0 in case of batch mode, and <0 in case of failure (cannot connect
1408/// to display dpyName).
1409
1410Int_t TVirtualX::OpenDisplay(const char * /*dpyName*/)
1411{
1412 return 0;
1413}
1414
1415////////////////////////////////////////////////////////////////////////////////
1416/// Closes connection to display server and destroys all windows.
1417
1419{
1420}
1421
1422////////////////////////////////////////////////////////////////////////////////
1423/// Returns handle to display (might be useful in some cases where
1424/// direct X11 manipulation outside of TVirtualX is needed, e.g. GL
1425/// interface).
1426
1428{
1429 return 0;
1430}
1431
1432////////////////////////////////////////////////////////////////////////////////
1433/// Returns handle to visual.
1434///
1435/// Might be useful in some cases where direct X11 manipulation outside
1436/// of TVirtualX is needed, e.g. GL interface.
1437
1439{
1440 return 0;
1441}
1442
1443////////////////////////////////////////////////////////////////////////////////
1444/// Returns screen number.
1445///
1446/// Might be useful in some cases where direct X11 manipulation outside
1447/// of TVirtualX is needed, e.g. GL interface.
1448
1450{
1451 return 0;
1452}
1453
1454////////////////////////////////////////////////////////////////////////////////
1455/// Returns depth of screen (number of bit planes).
1456/// Equivalent to GetPlanes().
1457
1459{
1460 return 0;
1461}
1462
1463////////////////////////////////////////////////////////////////////////////////
1464/// Returns handle to colormap.
1465///
1466/// Might be useful in some cases where direct X11 manipulation outside
1467/// of TVirtualX is needed, e.g. GL interface.
1468
1470{
1471 return 0;
1472}
1473
1474////////////////////////////////////////////////////////////////////////////////
1475/// Returns handle to the default root window created when calling
1476/// XOpenDisplay().
1477
1479{
1480 return 0;
1481}
1482
1483////////////////////////////////////////////////////////////////////////////////
1484/// Returns the atom identifier associated with the specified "atom_name"
1485/// string. If "only_if_exists" is False, the atom is created if it does
1486/// not exist. If the atom name is not in the Host Portable Character
1487/// Encoding, the result is implementation dependent. Uppercase and
1488/// lowercase matter; the strings "thing", "Thing", and "thinG" all
1489/// designate different atoms.
1490
1491Atom_t TVirtualX::InternAtom(const char * /*atom_name*/,
1492 Bool_t /*only_if_exist*/)
1493{
1494 return 0;
1495}
1496
1497////////////////////////////////////////////////////////////////////////////////
1498/// Returns the parent of the window "id".
1499
1501{
1502 return 0;
1503}
1504
1505////////////////////////////////////////////////////////////////////////////////
1506/// Provides the most common way for accessing a font: opens (loads) the
1507/// specified font and returns a pointer to the appropriate FontStruct_t
1508/// structure. If the font does not exist, it returns NULL.
1509
1510FontStruct_t TVirtualX::LoadQueryFont(const char * /*font_name*/)
1511{
1512 return 0;
1513}
1514
1515////////////////////////////////////////////////////////////////////////////////
1516/// Returns the font handle of the specified font structure "fs".
1517
1519{
1520 return 0;
1521}
1522
1523////////////////////////////////////////////////////////////////////////////////
1524/// Explicitly deletes the font structure "fs" obtained via LoadQueryFont().
1525
1527{
1528}
1529
1530////////////////////////////////////////////////////////////////////////////////
1531/// Creates a graphics context using the provided GCValues_t *gval structure.
1532/// The mask data member of gval specifies which components in the GC are
1533/// to be set using the information in the specified values structure.
1534/// It returns a graphics context handle GContext_t that can be used with any
1535/// destination drawable or O if the creation falls.
1536
1538{
1539 return 0;
1540}
1541
1542////////////////////////////////////////////////////////////////////////////////
1543/// Changes the components specified by the mask in gval for the specified GC.
1544///
1545/// \param [in] gc specifies the GC to be changed
1546/// \param [in] gval specifies the mask and the values to be set
1547///
1548/// (see also the GCValues_t structure)
1549
1551{
1552}
1553
1554////////////////////////////////////////////////////////////////////////////////
1555/// Copies the specified components from the source GC "org" to the
1556/// destination GC "dest". The "mask" defines which component to copy
1557/// and it is a data member of GCValues_t.
1558
1559void TVirtualX::CopyGC(GContext_t /*org*/, GContext_t /*dest*/, Mask_t /*mask*/)
1560{
1561}
1562
1563////////////////////////////////////////////////////////////////////////////////
1564/// Deletes the specified GC "gc".
1565
1567{
1568}
1569
1570////////////////////////////////////////////////////////////////////////////////
1571/// Creates the specified cursor. (just return cursor from cursor pool).
1572/// The cursor can be:
1573/// ~~~ {.cpp}
1574/// kBottomLeft, kBottomRight, kTopLeft, kTopRight,
1575/// kBottomSide, kLeftSide, kTopSide, kRightSide,
1576/// kMove, kCross, kArrowHor, kArrowVer,
1577/// kHand, kRotate, kPointer, kArrowRight,
1578/// kCaret, kWatch
1579/// ~~~
1580
1582{
1583 return 0;
1584}
1585
1586////////////////////////////////////////////////////////////////////////////////
1587/// Sets the cursor "curid" to be used when the pointer is in the
1588/// window "id".
1589
1591{
1592}
1593
1594////////////////////////////////////////////////////////////////////////////////
1595/// Creates a pixmap of the specified width and height and returns
1596/// a pixmap ID that identifies it.
1597
1599{
1600 return kNone;
1601}
1602////////////////////////////////////////////////////////////////////////////////
1603/// Creates a pixmap from bitmap data of the width, height, and depth you
1604/// specified and returns a pixmap that identifies it. The width and height
1605/// arguments must be nonzero. The depth argument must be one of the depths
1606/// supported by the screen of the specified drawable.
1607///
1608/// \param [in] id specifies which screen the pixmap is created on
1609/// \param [in] bitmap the data in bitmap format
1610/// \param [in] width, height define the dimensions of the pixmap
1611/// \param [in] forecolor the foreground pixel values to use
1612/// \param [in] backcolor the background pixel values to use
1613/// \param [in] depth the depth of the pixmap
1614
1615Pixmap_t TVirtualX::CreatePixmap(Drawable_t /*id*/, const char * /*bitmap*/,
1616 UInt_t /*width*/, UInt_t /*height*/,
1617 ULong_t /*forecolor*/, ULong_t /*backcolor*/,
1618 Int_t /*depth*/)
1619{
1620 return 0;
1621}
1622
1623////////////////////////////////////////////////////////////////////////////////
1624/// Creates a bitmap (i.e. pixmap with depth 1) from the bitmap data.
1625///
1626/// \param [in] id specifies which screen the pixmap is created on
1627/// \param [in] bitmap the data in bitmap format
1628/// \param [in] width, height define the dimensions of the pixmap
1629
1630Pixmap_t TVirtualX::CreateBitmap(Drawable_t /*id*/, const char * /*bitmap*/,
1631 UInt_t /*width*/, UInt_t /*height*/)
1632{
1633 return 0;
1634}
1635
1636////////////////////////////////////////////////////////////////////////////////
1637/// Explicitly deletes the pixmap resource "pmap".
1638
1640{
1641}
1642
1643////////////////////////////////////////////////////////////////////////////////
1644/// Creates a picture pict from data in file "filename". The picture
1645/// attributes "attr" are used for input and output. Returns kTRUE in
1646/// case of success, kFALSE otherwise. If the mask "pict_mask" does not
1647/// exist it is set to kNone.
1648
1650 const char * /*filename*/,
1651 Pixmap_t &/*pict*/,
1652 Pixmap_t &/*pict_mask*/,
1653 PictureAttributes_t &/*attr*/)
1654{
1655 return kFALSE;
1656}
1657
1658////////////////////////////////////////////////////////////////////////////////
1659/// Creates a picture pict from data in bitmap format. The picture
1660/// attributes "attr" are used for input and output. Returns kTRUE in
1661/// case of success, kFALSE otherwise. If the mask "pict_mask" does not
1662/// exist it is set to kNone.
1663
1665 Pixmap_t &/*pict*/,
1666 Pixmap_t &/*pict_mask*/,
1667 PictureAttributes_t & /*attr*/)
1668{
1669 return kFALSE;
1670}
1671////////////////////////////////////////////////////////////////////////////////
1672/// Reads picture data from file "filename" and store it in "ret_data".
1673/// Returns kTRUE in case of success, kFALSE otherwise.
1674
1676 char *** /*ret_data*/)
1677{
1678 return kFALSE;
1679}
1680
1681////////////////////////////////////////////////////////////////////////////////
1682/// Delete picture data created by the function ReadPictureDataFromFile.
1683
1684void TVirtualX::DeletePictureData(void * /*data*/)
1685{
1686}
1687
1688////////////////////////////////////////////////////////////////////////////////
1689/// Sets the dash-offset and dash-list attributes for dashed line styles
1690/// in the specified GC. There must be at least one element in the
1691/// specified dash_list. The initial and alternating elements (second,
1692/// fourth, and so on) of the dash_list are the even dashes, and the
1693/// others are the odd dashes. Each element in the "dash_list" array
1694/// specifies the length (in pixels) of a segment of the pattern.
1695///
1696/// \param [in] gc specifies the GC (see GCValues_t structure)
1697/// \param [in] offset the phase of the pattern for the dashed line-style you
1698/// want to set for the specified GC.
1699/// \param [in] dash_list the dash-list for the dashed line-style you want to set
1700/// for the specified GC
1701/// \param [in] n the number of elements in dash_list
1702/// (see also the GCValues_t structure)
1703
1704void TVirtualX::SetDashes(GContext_t /*gc*/, Int_t /*offset*/,
1705 const char * /*dash_list*/, Int_t /*n*/)
1706{
1707}
1708
1709////////////////////////////////////////////////////////////////////////////////
1710/// Frees color cell with specified pixel value.
1711
1712void TVirtualX::FreeColor(Colormap_t /*cmap*/, ULong_t /*pixel*/)
1713{
1714}
1715
1716////////////////////////////////////////////////////////////////////////////////
1717/// Returns the number of events that have been received from the X server
1718/// but have not been removed from the event queue.
1719
1721{
1722 return 0;
1723}
1724
1725////////////////////////////////////////////////////////////////////////////////
1726/// Sets the sound bell. Percent is loudness from -100% to 100%.
1727
1728void TVirtualX::Bell(Int_t /*percent*/)
1729{
1730}
1731
1732////////////////////////////////////////////////////////////////////////////////
1733/// Combines the specified rectangle of "src" with the specified rectangle
1734/// of "dest" according to the "gc".
1735///
1736/// \param [in] src source rectangle
1737/// \param [in] dest destination rectangle
1738/// \param [in] gc graphics context
1739/// \param [in] src_x, src_y specify the x and y coordinates, which are relative
1740/// to the origin of the source rectangle and specify
1741/// upper-left corner.
1742/// \param [in] width, height the width and height, which are the dimensions of both
1743/// the source and destination rectangles
1744/// \param [in] dest_x, dest_y specify the upper-left corner of the destination
1745/// rectangle
1746///
1747/// GC components in use: function, plane-mask, subwindow-mode,
1748/// graphics-exposure, clip-x-origin, clip-y-origin, and clip-mask.
1749/// (see also the GCValues_t structure)
1750
1752 GContext_t /*gc*/, Int_t /*src_x*/, Int_t /*src_y*/,
1753 UInt_t /*width*/, UInt_t /*height*/,
1754 Int_t /*dest_x*/, Int_t /*dest_y*/)
1755{
1756}
1757
1758////////////////////////////////////////////////////////////////////////////////
1759/// Changes the attributes of the specified window "id" according the
1760/// values provided in "attr". The mask data member of "attr" specifies
1761/// which window attributes are defined in the attributes argument.
1762/// This mask is the bitwise inclusive OR of the valid attribute mask
1763/// bits; if it is zero, the attributes are ignored.
1764
1766 SetWindowAttributes_t * /*attr*/)
1767{
1768}
1769
1770////////////////////////////////////////////////////////////////////////////////
1771/// Alters the property for the specified window and causes the X server
1772/// to generate a PropertyNotify event on that window.
1773///
1774/// \param [in] id the window whose property you want to change
1775/// \param [in] property specifies the property name
1776/// \param [in] type the type of the property; the X server does not
1777/// interpret the type but simply passes it back to
1778/// an application that might ask about the window
1779/// properties
1780/// \param [in] data the property data
1781/// \param [in] len the length of the specified data format
1782
1784 Atom_t /*type*/, UChar_t * /*data*/,
1785 Int_t /*len*/)
1786{
1787}
1788
1789////////////////////////////////////////////////////////////////////////////////
1790/// Alters the property for the specified window and causes the X server
1791/// to generate a PropertyNotify event on that window.
1792///
1793/// \param [in] id the window whose property you want to change
1794/// \param [in] hint specifies the type to be changed
1795
1797{
1798}
1799
1800////////////////////////////////////////////////////////////////////////////////
1801/// Uses the components of the specified GC to draw a line between the
1802/// specified set of points (x1, y1) and (x2, y2).
1803///
1804/// GC components in use: function, plane-mask, line-width, line-style,
1805/// cap-style, fill-style, subwindow-mode, clip-x-origin, clip-y-origin,
1806/// and clip-mask.
1807///
1808/// GC mode-dependent components: foreground, background, tile, stipple,
1809/// tile-stipple-x-origin, tile-stipple-y-origin, dash-offset, dash-list.
1810/// (see also the GCValues_t structure)
1811
1813 Int_t /*x1*/, Int_t /*y1*/, Int_t /*x2*/, Int_t /*y2*/)
1814{
1815}
1816
1817////////////////////////////////////////////////////////////////////////////////
1818/// Paints a rectangular area in the specified window "id" according to
1819/// the specified dimensions with the window's background pixel or pixmap.
1820///
1821/// \param [in] id specifies the window
1822/// \param [in] x, y coordinates, which are relative to the origin
1823/// \param [in] w, h the width and height which define the rectangle dimensions
1824
1825void TVirtualX::ClearArea(Window_t /*id*/, Int_t /*x*/, Int_t /*y*/,
1826 UInt_t /*w*/, UInt_t /*h*/)
1827{
1828}
1829
1830////////////////////////////////////////////////////////////////////////////////
1831/// Check if there is for window "id" an event of type "type". If there
1832/// is it fills in the event structure and return true. If no such event
1833/// return false.
1834
1836 Event_t &/*ev*/)
1837{
1838 return kFALSE;
1839}
1840
1841////////////////////////////////////////////////////////////////////////////////
1842/// Specifies the event "ev" is to be sent to the window "id".
1843/// This function requires you to pass an event mask.
1844
1846{
1847}
1848
1849////////////////////////////////////////////////////////////////////////////////
1850/// Force processing of event, sent by SendEvent before.
1851
1853{
1854}
1855
1856////////////////////////////////////////////////////////////////////////////////
1857/// Tells WM to send message when window is closed via WM.
1858
1860{
1861}
1862
1863////////////////////////////////////////////////////////////////////////////////
1864/// Turns key auto repeat on (kTRUE) or off (kFALSE).
1865
1867{
1868}
1869
1870////////////////////////////////////////////////////////////////////////////////
1871/// Establishes a passive grab on the keyboard. In the future, the
1872/// keyboard is actively grabbed, the last-keyboard-grab time is set
1873/// to the time at which the key was pressed (as transmitted in the
1874/// KeyPress event), and the KeyPress event is reported if all of the
1875/// following conditions are true:
1876///
1877/// - the keyboard is not grabbed and the specified key (which can
1878/// itself be a modifier key) is logically pressed when the
1879/// specified modifier keys are logically down, and no other
1880/// modifier keys are logically down;
1881/// - either the grab window "id" is an ancestor of (or is) the focus
1882/// window, or "id" is a descendant of the focus window and contains
1883/// the pointer;
1884/// - a passive grab on the same key combination does not exist on any
1885/// ancestor of grab_window
1886///
1887/// \param [in] id window id
1888/// \param [in] keycode specifies the KeyCode or AnyKey
1889/// \param [in] modifier specifies the set of keymasks or AnyModifier; the mask is
1890/// the bitwise inclusive OR of the valid keymask bits
1891/// \param [in] grab a switch between grab/ungrab key
1892/// grab = kTRUE grab the key and modifier
1893/// grab = kFALSE ungrab the key and modifier
1894
1895void TVirtualX::GrabKey(Window_t /*id*/, Int_t /*keycode*/, UInt_t /*modifier*/,
1896 Bool_t /*grab = kTRUE*/)
1897{
1898}
1899
1900////////////////////////////////////////////////////////////////////////////////
1901/// Establishes a passive grab on a certain mouse button. That is, when a
1902/// certain mouse button is hit while certain modifier's (Shift, Control,
1903/// Meta, Alt) are active then the mouse will be grabbed for window id.
1904/// When grab is false, ungrab the mouse button for this button and modifier.
1905
1907 UInt_t /*modifier*/, UInt_t /*evmask*/,
1908 Window_t /*confine*/, Cursor_t /*cursor*/,
1909 Bool_t /*grab = kTRUE*/)
1910{
1911}
1912
1913////////////////////////////////////////////////////////////////////////////////
1914/// Establishes an active pointer grab. While an active pointer grab is in
1915/// effect, further pointer events are only reported to the grabbing
1916/// client window.
1917
1919 Window_t /*confine*/, Cursor_t /*cursor*/,
1920 Bool_t /*grab = kTRUE*/,
1921 Bool_t /*owner_events = kTRUE*/)
1922{
1923}
1924
1925////////////////////////////////////////////////////////////////////////////////
1926/// Sets the window name.
1927
1928void TVirtualX::SetWindowName(Window_t /*id*/, char * /*name*/)
1929{
1930}
1931
1932////////////////////////////////////////////////////////////////////////////////
1933/// Sets the window icon name.
1934
1935void TVirtualX::SetIconName(Window_t /*id*/, char * /*name*/)
1936{
1937}
1938
1939////////////////////////////////////////////////////////////////////////////////
1940/// Sets the icon name pixmap.
1941
1943{
1944}
1945
1946////////////////////////////////////////////////////////////////////////////////
1947/// Sets the windows class and resource name.
1948
1949void TVirtualX::SetClassHints(Window_t /*id*/, char * /*className*/,
1950 char * /*resourceName*/)
1951{
1952}
1953
1954////////////////////////////////////////////////////////////////////////////////
1955/// Sets decoration style.
1956
1957void TVirtualX::SetMWMHints(Window_t /*id*/, UInt_t /*value*/, UInt_t /*funcs*/,
1958 UInt_t /*input*/)
1959{
1960}
1961
1962////////////////////////////////////////////////////////////////////////////////
1963/// Tells the window manager the desired position [x,y] of window "id".
1964
1966{
1967}
1968
1969////////////////////////////////////////////////////////////////////////////////
1970/// Tells window manager the desired size of window "id".
1971///
1972/// \param [in] id window identifier
1973/// \param [in] w the width
1974/// \param [in] h the height
1975
1976void TVirtualX::SetWMSize(Window_t /*id*/, UInt_t /*w*/, UInt_t /*h*/)
1977{
1978}
1979
1980////////////////////////////////////////////////////////////////////////////////
1981/// Gives the window manager minimum and maximum size hints of the window
1982/// "id". Also specify via "winc" and "hinc" the resize increments.
1983///
1984/// \param [in] id window identifier
1985/// \param [in] wmin, hmin specify the minimum window size
1986/// \param [in] wmax, hmax specify the maximum window size
1987/// \param [in] winc, hinc define an arithmetic progression of sizes into which
1988/// the window to be resized (minimum to maximum)
1989
1990void TVirtualX::SetWMSizeHints(Window_t /*id*/, UInt_t /*wmin*/, UInt_t /*hmin*/,
1991 UInt_t /*wmax*/, UInt_t /*hmax*/,
1992 UInt_t /*winc*/, UInt_t /*hinc*/)
1993{
1994}
1995
1996////////////////////////////////////////////////////////////////////////////////
1997/// Sets the initial state of the window "id": either kNormalState
1998/// or kIconicState.
1999
2001{
2002}
2003
2004////////////////////////////////////////////////////////////////////////////////
2005/// Tells window manager that the window "id" is a transient window
2006/// of the window "main_id". A window manager may decide not to decorate
2007/// a transient window or may treat it differently in other ways.
2008
2010{
2011}
2012
2013////////////////////////////////////////////////////////////////////////////////
2014/// Each character image, as defined by the font in the GC, is treated as an
2015/// additional mask for a fill operation on the drawable.
2016///
2017/// \param [in] id the drawable
2018/// \param [in] gc the GC
2019/// \param [in] x, y coordinates, which are relative to the origin of the specified
2020/// drawable and define the origin of the first character
2021/// \param [in] s the character string
2022/// \param [in] len the number of characters in the string argument
2023///
2024/// GC components in use: function, plane-mask, fill-style, font,
2025/// subwindow-mode, clip-x-origin, clip-y-origin, and clip-mask.
2026/// GC mode-dependent components: foreground, background, tile, stipple,
2027/// tile-stipple-x-origin, and tile-stipple-y-origin.
2028/// (see also the GCValues_t structure)
2029
2031 Int_t /*y*/, const char * /*s*/, Int_t /*len*/)
2032{
2033}
2034
2035////////////////////////////////////////////////////////////////////////////////
2036/// Return length of the string "s" in pixels. Size depends on font.
2037
2038Int_t TVirtualX::TextWidth(FontStruct_t /*font*/, const char * /*s*/,
2039 Int_t /*len*/)
2040{
2041 return 5;
2042}
2043
2044////////////////////////////////////////////////////////////////////////////////
2045/// Returns the font properties.
2046
2053
2054////////////////////////////////////////////////////////////////////////////////
2055/// Returns the components specified by the mask in "gval" for the
2056/// specified GC "gc" (see also the GCValues_t structure)
2057
2059{
2060 gval.fMask = 0;
2061}
2062
2063////////////////////////////////////////////////////////////////////////////////
2064/// Return the font associated with the graphics context gc
2065
2067{
2068 return 0;
2069}
2070
2071////////////////////////////////////////////////////////////////////////////////
2072/// Retrieves the associated font structure of the font specified font
2073/// handle "fh".
2074///
2075/// Free returned FontStruct_t using FreeFontStruct().
2076
2078{
2079 return 0;
2080}
2081
2082////////////////////////////////////////////////////////////////////////////////
2083/// Frees the font structure "fs". The font itself will be freed when
2084/// no other resource references it.
2085
2089
2090////////////////////////////////////////////////////////////////////////////////
2091/// Clears the entire area in the specified window and it is equivalent to
2092/// ClearArea(id, 0, 0, 0, 0)
2093
2095{
2096}
2097
2098////////////////////////////////////////////////////////////////////////////////
2099/// Converts the "keysym" to the appropriate keycode. For example,
2100/// keysym is a letter and keycode is the matching keyboard key (which
2101/// is dependent on the current keyboard mapping). If the specified
2102/// "keysym" is not defined for any keycode, returns zero.
2103
2105{
2106 return 0;
2107}
2108
2109////////////////////////////////////////////////////////////////////////////////
2110/// Fills the specified rectangle defined by [x,y] [x+w,y] [x+w,y+h] [x,y+h].
2111/// using the GC you specify.
2112///
2113/// GC components in use are: function, plane-mask, fill-style,
2114/// subwindow-mode, clip-x-origin, clip-y-origin, clip-mask.
2115/// GC mode-dependent components: foreground, background, tile, stipple,
2116/// tile-stipple-x-origin, and tile-stipple-y-origin.
2117/// (see also the GCValues_t structure)
2118
2120 Int_t /*x*/, Int_t /*y*/,
2121 UInt_t /*w*/, UInt_t /*h*/)
2122{
2123}
2124
2125////////////////////////////////////////////////////////////////////////////////
2126/// Draws rectangle outlines of [x,y] [x+w,y] [x+w,y+h] [x,y+h]
2127///
2128/// GC components in use: function, plane-mask, line-width, line-style,
2129/// cap-style, join-style, fill-style, subwindow-mode, clip-x-origin,
2130/// clip-y-origin, clip-mask.
2131/// GC mode-dependent components: foreground, background, tile, stipple,
2132/// tile-stipple-x-origin, tile-stipple-y-origin, dash-offset, dash-list.
2133/// (see also the GCValues_t structure)
2134
2136 Int_t /*x*/, Int_t /*y*/,
2137 UInt_t /*w*/, UInt_t /*h*/)
2138{
2139}
2140
2141////////////////////////////////////////////////////////////////////////////////
2142/// Draws multiple line segments. Each line is specified by a pair of points.
2143///
2144/// \param [in] id Drawable identifier
2145/// \param [in] gc graphics context
2146/// \param [in] *seg specifies an array of segments
2147/// \param [in] nseg specifies the number of segments in the array
2148///
2149/// GC components in use: function, plane-mask, line-width, line-style,
2150/// cap-style, join-style, fill-style, subwindow-mode, clip-x-origin,
2151/// clip-y-origin, clip-mask.
2152///
2153/// GC mode-dependent components: foreground, background, tile, stipple,
2154/// tile-stipple-x-origin, tile-stipple-y-origin, dash-offset, and dash-list.
2155/// (see also the GCValues_t structure)
2156
2158 Segment_t * /*seg*/, Int_t /*nseg*/)
2159{
2160}
2161
2162////////////////////////////////////////////////////////////////////////////////
2163/// Defines which input events the window is interested in. By default
2164/// events are propagated up the window stack. This mask can also be
2165/// set at window creation time via the SetWindowAttributes_t::fEventMask
2166/// attribute.
2167
2169{
2170}
2171
2172////////////////////////////////////////////////////////////////////////////////
2173/// Returns the window id of the window having the input focus.
2174
2176{
2177 return kNone;
2178}
2179
2180////////////////////////////////////////////////////////////////////////////////
2181/// Changes the input focus to specified window "id".
2182
2184{
2185}
2186
2187////////////////////////////////////////////////////////////////////////////////
2188/// Returns the window id of the current owner of the primary selection.
2189/// That is the window in which, for example some text is selected.
2190
2195
2196////////////////////////////////////////////////////////////////////////////////
2197/// Makes the window "id" the current owner of the primary selection.
2198/// That is the window in which, for example some text is selected.
2199
2203
2204////////////////////////////////////////////////////////////////////////////////
2205/// Causes a SelectionRequest event to be sent to the current primary
2206/// selection owner. This event specifies the selection property
2207/// (primary selection), the format into which to convert that data before
2208/// storing it (target = XA_STRING), the property in which the owner will
2209/// place the information (sel_property), the window that wants the
2210/// information (id), and the time of the conversion request (when).
2211/// The selection owner responds by sending a SelectionNotify event, which
2212/// confirms the selected atom and type.
2213
2215 Time_t /*when*/)
2216{
2217}
2218
2219////////////////////////////////////////////////////////////////////////////////
2220/// Converts the keycode from the event structure to a key symbol (according
2221/// to the modifiers specified in the event structure and the current
2222/// keyboard mapping). In "buf" a null terminated ASCII string is returned
2223/// representing the string that is currently mapped to the key code.
2224///
2225/// \param [in] event specifies the event structure to be used
2226/// \param [in] buf returns the translated characters
2227/// \param [in] buflen the length of the buffer
2228/// \param [in] keysym returns the "keysym" computed from the event
2229/// if this argument is not NULL
2230
2231void TVirtualX::LookupString(Event_t * /*event*/, char * /*buf*/,
2232 Int_t /*buflen*/, UInt_t &keysym)
2233{
2234 keysym = 0;
2235}
2236
2237////////////////////////////////////////////////////////////////////////////////
2238/// Translates coordinates in one window to the coordinate space of another
2239/// window. It takes the "src_x" and "src_y" coordinates relative to the
2240/// source window's origin and returns these coordinates to "dest_x" and
2241/// "dest_y" relative to the destination window's origin.
2242///
2243/// \param [in] src the source window
2244/// \param [in] dest the destination window
2245/// \param [in] src_x, src_y coordinates within the source window
2246/// \param [in] dest_x, dest_y coordinates within the destination window
2247/// \param [in] child returns the child of "dest" if the coordinates
2248/// are contained in a mapped child of the destination
2249/// window; otherwise, child is set to 0
2250
2252 Int_t /*src_x*/, Int_t /*src_y*/,
2254 Window_t &child)
2255{
2256 dest_x = dest_y = 0;
2257 child = 0;
2258}
2259
2260////////////////////////////////////////////////////////////////////////////////
2261/// Returns the location and the size of window "id"
2262///
2263/// \param [in] id drawable identifier
2264/// \param [in] x, y coordinates of the upper-left outer corner relative to the
2265/// parent window's origin
2266/// \param [in] w, h the inside size of the window, not including the border
2267
2269 UInt_t &w, UInt_t &h)
2270{
2271 x = y = 0;
2272 w = h = 1;
2273}
2274
2275////////////////////////////////////////////////////////////////////////////////
2276/// Fills the region closed by the specified path. The path is closed
2277/// automatically if the last point in the list does not coincide with the
2278/// first point.
2279///
2280/// \param [in] id window identifier
2281/// \param [in] gc graphics context
2282/// \param [in] *points specifies an array of points
2283/// \param [in] npnt specifies the number of points in the array
2284///
2285/// GC components in use: function, plane-mask, fill-style, fill-rule,
2286/// subwindow-mode, clip-x-origin, clip-y-origin, and clip-mask. GC
2287/// mode-dependent components: foreground, background, tile, stipple,
2288/// tile-stipple-x-origin, and tile-stipple-y-origin.
2289/// (see also the GCValues_t structure)
2290
2292 /*points*/, Int_t /*npnt*/) {
2293}
2294
2295////////////////////////////////////////////////////////////////////////////////
2296/// Returns the root window the pointer is logically on and the pointer
2297/// coordinates relative to the root window's origin.
2298///
2299/// \param [in] id specifies the window
2300/// \param [in] rootw the root window that the pointer is in
2301/// \param [in] childw the child window that the pointer is located in, if any
2302/// \param [in] root_x, root_y the pointer coordinates relative to the root window's
2303/// origin
2304/// \param [in] win_x, win_y the pointer coordinates relative to the specified
2305/// window "id"
2306/// \param [in] mask the current state of the modifier keys and pointer
2307/// buttons
2308
2312{
2313 rootw = childw = kNone;
2314 root_x = root_y = win_x = win_y = 0;
2315 mask = 0;
2316}
2317
2318////////////////////////////////////////////////////////////////////////////////
2319/// Sets the foreground color for the specified GC (shortcut for ChangeGC
2320/// with only foreground mask set).
2321///
2322/// \param [in] gc specifies the GC
2323/// \param [in] foreground the foreground you want to set
2324///
2325/// (see also the GCValues_t structure)
2326
2327void TVirtualX::SetForeground(GContext_t /*gc*/, ULong_t /*foreground*/)
2328{
2329}
2330
2331////////////////////////////////////////////////////////////////////////////////
2332/// Sets clipping rectangles in graphics context. [x,y] specify the origin
2333/// of the rectangles. "recs" specifies an array of rectangles that define
2334/// the clipping mask and "n" is the number of rectangles.
2335/// (see also the GCValues_t structure)
2336
2338 Rectangle_t * /*recs*/, Int_t /*n*/)
2339{
2340}
2341
2342////////////////////////////////////////////////////////////////////////////////
2343/// Flushes (mode = 0, default) or synchronizes (mode = 1) X output buffer.
2344/// Flush flushes output buffer. Sync flushes buffer and waits till all
2345/// requests have been processed by X server.
2346
2347void TVirtualX::Update(Int_t /*mode = 0*/)
2348{
2349}
2350
2351////////////////////////////////////////////////////////////////////////////////
2352/// Creates a new empty region.
2353
2355{
2356 return 0;
2357}
2358
2359////////////////////////////////////////////////////////////////////////////////
2360/// Destroys the region "reg".
2361
2363{
2364}
2365
2366////////////////////////////////////////////////////////////////////////////////
2367/// Updates the destination region from a union of the specified rectangle
2368/// and the specified source region.
2369///
2370/// \param [in] rect specifies the rectangle
2371/// \param [in] src specifies the source region to be used
2372/// \param [in] dest returns the destination region
2373
2375 Region_t /*dest*/)
2376{
2377}
2378
2379////////////////////////////////////////////////////////////////////////////////
2380/// Returns a region for the polygon defined by the points array.
2381///
2382/// \param [in] points specifies an array of points
2383/// \param [in] np specifies the number of points in the polygon
2384/// \param [in] winding specifies the winding-rule is set (kTRUE) or not(kFALSE)
2385
2387 Bool_t /*winding*/)
2388{
2389 return 0;
2390}
2391
2392////////////////////////////////////////////////////////////////////////////////
2393/// Computes the union of two regions.
2394///
2395/// \param [in] rega, regb specify the two regions with which you want to perform
2396/// the computation
2397/// \param [in] result returns the result of the computation
2398
2400 Region_t /*result*/)
2401{
2402}
2403
2404////////////////////////////////////////////////////////////////////////////////
2405/// Computes the intersection of two regions.
2406///
2407/// \param [in] rega, regb specify the two regions with which you want to perform
2408/// the computation
2409/// \param [in] result returns the result of the computation
2410
2412 Region_t /*result*/)
2413{
2414}
2415
2416////////////////////////////////////////////////////////////////////////////////
2417/// Subtracts regb from rega and stores the results in result.
2418
2420 Region_t /*result*/)
2421{
2422}
2423
2424////////////////////////////////////////////////////////////////////////////////
2425/// Calculates the difference between the union and intersection of
2426/// two regions.
2427///
2428/// \param [in] rega, regb specify the two regions with which you want to perform
2429/// the computation
2430/// \param [in] result returns the result of the computation
2431
2433 Region_t /*result*/)
2434{
2435}
2436
2437////////////////////////////////////////////////////////////////////////////////
2438/// Returns kTRUE if the region reg is empty.
2439
2441{
2442 return kFALSE;
2443}
2444
2445////////////////////////////////////////////////////////////////////////////////
2446/// Returns kTRUE if the point [x, y] is contained in the region reg.
2447
2449{
2450 return kFALSE;
2451}
2452
2453////////////////////////////////////////////////////////////////////////////////
2454/// Returns kTRUE if the two regions have the same offset, size, and shape.
2455
2457{
2458 return kFALSE;
2459}
2460
2461////////////////////////////////////////////////////////////////////////////////
2462/// Returns smallest enclosing rectangle.
2463
2465{
2466}
2467
2468////////////////////////////////////////////////////////////////////////////////
2469/// Returns list of font names matching fontname regexp, like "-*-times-*".
2470/// The pattern string can contain any characters, but each asterisk (*)
2471/// is a wildcard for any number of characters, and each question mark (?)
2472/// is a wildcard for a single character. If the pattern string is not in
2473/// the Host Portable Character Encoding, the result is implementation
2474/// dependent. Use of uppercase or lowercase does not matter. Each returned
2475/// string is null-terminated.
2476///
2477/// \param [in] fontname specifies the null-terminated pattern string that can
2478/// contain wildcard characters
2479/// \param [in] max specifies the maximum number of names to be returned
2480/// \param [in] count returns the actual number of font names
2481
2482char **TVirtualX::ListFonts(const char * /*fontname*/, Int_t /*max*/, Int_t & count)
2483{
2484 count=0;
2485 return nullptr;
2486}
2487
2488////////////////////////////////////////////////////////////////////////////////
2489/// Frees the specified the array of strings "fontlist".
2490
2491void TVirtualX::FreeFontNames(char ** /*fontlist*/)
2492{
2493}
2494
2495////////////////////////////////////////////////////////////////////////////////
2496/// Allocates the memory needed for an drawable.
2497///
2498/// \param [in] width the width of the image, in pixels
2499/// \param [in] height the height of the image, in pixels
2500
2502{
2503 return 0;
2504}
2505
2506////////////////////////////////////////////////////////////////////////////////
2507/// Returns the width and height of the image id
2508
2510 UInt_t &/*height*/)
2511{
2512}
2513
2514////////////////////////////////////////////////////////////////////////////////
2515/// Overwrites the pixel in the image with the specified pixel value.
2516/// The image must contain the x and y coordinates.
2517///
2518/// \param [in] id specifies the image
2519/// \param [in] x, y coordinates
2520/// \param [in] pixel the new pixel value
2521
2522void TVirtualX::PutPixel(Drawable_t /*id*/, Int_t /*x*/, Int_t /*y*/,
2523 ULong_t /*pixel*/)
2524{
2525}
2526
2527////////////////////////////////////////////////////////////////////////////////
2528/// Combines an image with a rectangle of the specified drawable. The
2529/// section of the image defined by the x, y, width, and height arguments
2530/// is drawn on the specified part of the drawable.
2531///
2532/// \param [in] id the drawable
2533/// \param [in] gc the GC
2534/// \param [in] img the image you want combined with the rectangle
2535/// \param [in] dx the offset in X from the left edge of the image
2536/// \param [in] dy the offset in Y from the top edge of the image
2537/// \param [in] x, y coordinates, which are relative to the origin of the
2538/// drawable and are the coordinates of the subimage
2539/// \param [in] w, h the width and height of the subimage, which define the
2540/// rectangle dimensions
2541///
2542/// GC components in use: function, plane-mask, subwindow-mode,
2543/// clip-x-origin, clip-y-origin, and clip-mask.
2544/// GC mode-dependent components: foreground and background.
2545/// (see also the GCValues_t structure)
2546
2548 Drawable_t /*img*/, Int_t /*dx*/, Int_t /*dy*/,
2549 Int_t /*x*/, Int_t /*y*/, UInt_t /*w*/, UInt_t /*h*/)
2550{
2551}
2552
2553////////////////////////////////////////////////////////////////////////////////
2554/// Deallocates the memory associated with the image img
2555
2557{
2558}
2559
2560////////////////////////////////////////////////////////////////////////////////
2561/// pointer to the current internal window used in canvas graphics
2562
2564{
2565 return (Window_t)0;
2566}
2567
2568////////////////////////////////////////////////////////////////////////////////
2569/// Returns an array of pixels created from a part of drawable (defined by x, y, w, h)
2570/// in format:
2571///
2572/// ~~~ {.cpp}
2573/// b1, g1, r1, 0, b2, g2, r2, 0 ... bn, gn, rn, 0 ..
2574/// ~~~
2575///
2576/// Pixels are numbered from left to right and from top to bottom.
2577/// By default all pixels from the whole drawable are returned.
2578///
2579/// Note that return array is 32-bit aligned
2580
2581unsigned char *TVirtualX::GetColorBits(Drawable_t /*wid*/, Int_t /*x*/, Int_t /*y*/,
2582 UInt_t /*w*/, UInt_t /*h*/)
2583{
2584 return nullptr;
2585}
2586
2587////////////////////////////////////////////////////////////////////////////////
2588/// create pixmap from RGB data. RGB data is in format:
2589///
2590/// ~~~ {.cpp}
2591/// b1, g1, r1, 0, b2, g2, r2, 0 ... bn, gn, rn, 0 ..
2592/// ~~~
2593///
2594/// Pixels are numbered from left to right and from top to bottom.
2595/// Note that data must be 32-bit aligned
2596
2597Pixmap_t TVirtualX::CreatePixmapFromData(unsigned char * /*bits*/, UInt_t /*width*/,
2598 UInt_t /*height*/)
2599{
2600 return (Pixmap_t)0;
2601}
2602
2603////////////////////////////////////////////////////////////////////////////////
2604/// The Non-rectangular Window Shape Extension adds non-rectangular
2605/// windows to the System.
2606/// This allows for making shaped (partially transparent) windows
2607
2611
2612////////////////////////////////////////////////////////////////////////////////
2613/// Returns the width of the screen in millimeters.
2614
2616{
2617 return 400;
2618}
2619
2620////////////////////////////////////////////////////////////////////////////////
2621/// Deletes the specified property only if the property was defined on the
2622/// specified window and causes the X server to generate a PropertyNotify
2623/// event on the window unless the property does not exist.
2624
2628
2629////////////////////////////////////////////////////////////////////////////////
2630/// Returns the actual type of the property; the actual format of the property;
2631/// the number of 8-bit, 16-bit, or 32-bit items transferred; the number of
2632/// bytes remaining to be read in the property; and a pointer to the data
2633/// actually returned.
2634
2636 Atom_t*, Int_t*, ULong_t*, ULong_t*, unsigned char**)
2637{
2638 return 0;
2639}
2640
2641////////////////////////////////////////////////////////////////////////////////
2642/// Changes the specified dynamic parameters if the pointer is actively
2643/// grabbed by the client and if the specified time is no earlier than the
2644/// last-pointer-grab time and no later than the current X server time.
2645
2649
2650////////////////////////////////////////////////////////////////////////////////
2651/// Requests that the specified selection be converted to the specified
2652/// target type.
2653
2657
2658////////////////////////////////////////////////////////////////////////////////
2659/// Changes the owner and last-change time for the specified selection.
2660
2665
2666////////////////////////////////////////////////////////////////////////////////
2667/// Alters the property for the specified window and causes the X server
2668/// to generate a PropertyNotify event on that window.
2669
2673
2674////////////////////////////////////////////////////////////////////////////////
2675/// Add XdndAware property and the list of drag and drop types to the
2676/// Window win.
2677
2681
2682////////////////////////////////////////////////////////////////////////////////
2683/// Add the list of drag and drop types to the Window win.
2684
2688
2689////////////////////////////////////////////////////////////////////////////////
2690/// Recursively search in the children of Window for a Window which is at
2691/// location x, y and is DND aware, with a maximum depth of maxd.
2692
2694{
2695 return kNone;
2696}
2697
2698////////////////////////////////////////////////////////////////////////////////
2699/// Checks if the Window is DND aware, and knows any of the DND formats
2700/// passed in argument.
2701
2706
2707////////////////////////////////////////////////////////////////////////////////
2708/// Start a modal session for a dialog window.
2709
2713
2714////////////////////////////////////////////////////////////////////////////////
2715/// Returns 1 if window system server supports extension given by the
2716/// argument, returns 0 in case extension is not supported and returns -1
2717/// in case of error (like server not initialized).
2718
2720{
2721 return -1;
2722}
2723
2724////////////////////////////////////////////////////////////////////////////////
2725/// Map the XftFont with the Graphics Context using it.
2726
2730
2731
Handle_t Atom_t
WM token.
Definition GuiTypes.h:38
Handle_t Region_t
Region handle.
Definition GuiTypes.h:33
Handle_t WinContext_t
Window drawing context.
Definition GuiTypes.h:30
EGEventType
Definition GuiTypes.h:60
@ kButtonPress
Definition GuiTypes.h:61
ECursor
Definition GuiTypes.h:373
Handle_t Pixmap_t
Pixmap handle.
Definition GuiTypes.h:31
Handle_t FontH_t
Font handle (as opposed to Font_t which is an index)
Definition GuiTypes.h:36
Handle_t Visual_t
Visual handle.
Definition GuiTypes.h:28
Handle_t Window_t
Window handle.
Definition GuiTypes.h:29
const Mask_t kDoRed
Definition GuiTypes.h:320
Handle_t Display_t
Display handle.
Definition GuiTypes.h:27
ULong_t Time_t
Event time.
Definition GuiTypes.h:43
Handle_t GContext_t
Graphics context handle.
Definition GuiTypes.h:39
EInitialState
Initial window mapping state.
Definition GuiTypes.h:346
Handle_t Drawable_t
Drawable handle.
Definition GuiTypes.h:32
Handle_t Cursor_t
Cursor handle.
Definition GuiTypes.h:35
const Handle_t kNone
Definition GuiTypes.h:89
@ kIsUnmapped
Definition GuiTypes.h:47
const Mask_t kDoGreen
Definition GuiTypes.h:321
const Mask_t kDoBlue
Definition GuiTypes.h:322
EMouseButton
Button names.
Definition GuiTypes.h:215
Handle_t Colormap_t
Colormap handle.
Definition GuiTypes.h:34
ULongptr_t Handle_t
Generic resource handle.
Definition GuiTypes.h:26
Handle_t FontStruct_t
Pointer to font structure.
Definition GuiTypes.h:40
#define d(i)
Definition RSha256.hxx:102
#define b(i)
Definition RSha256.hxx:100
#define g(i)
Definition RSha256.hxx:105
#define a(i)
Definition RSha256.hxx:99
#define h(i)
Definition RSha256.hxx:106
static Roo_reg_AGKInteg1D instance
short Style_t
Style number (short)
Definition RtypesCore.h:96
short Color_t
Color number (short)
Definition RtypesCore.h:99
unsigned char UChar_t
Unsigned Character 1 byte (unsigned char)
Definition RtypesCore.h:52
unsigned long ULong_t
Unsigned long integer 4 bytes (unsigned long). Size depends on architecture.
Definition RtypesCore.h:69
long Long_t
Signed long integer 4 bytes (long). Size depends on architecture.
Definition RtypesCore.h:68
unsigned long ULongptr_t
Unsigned integer large enough to hold a pointer (platform-dependent)
Definition RtypesCore.h:90
short Width_t
Line width (short)
Definition RtypesCore.h:98
float Float_t
Float 4 bytes (float)
Definition RtypesCore.h:71
short Font_t
Font number (short)
Definition RtypesCore.h:95
short Short_t
Signed Short integer 2 bytes (short)
Definition RtypesCore.h:53
constexpr Bool_t kFALSE
Definition RtypesCore.h:108
constexpr Bool_t kTRUE
Definition RtypesCore.h:107
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void chupy
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t mask
Option_t Option_t SetLineWidth
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t dest_x
Option_t Option_t SetFillStyle
Option_t Option_t SetTextSize
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize wid
Option_t Option_t DrawFillArea
Option_t Option_t mgn
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t r
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t child
Option_t Option_t SetLineColor
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void chupx
Option_t Option_t TPoint TPoint const char x2
Option_t Option_t TPoint TPoint const char x1
Option_t Option_t SetTextFont
Option_t Option_t TPoint TPoint angle
Option_t Option_t TPoint xy
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void xpos
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t dest_y
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t attr
Option_t Option_t TPoint TPoint const char mode
Option_t Option_t TPoint TPoint const char y2
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t nchar
Option_t Option_t TPoint DrawPolyMarker
Option_t Option_t SetFillColor
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void CopyPixmap
Option_t Option_t TPoint TPoint const char DrawLine
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void ypos
Option_t Option_t SetMarkerStyle
Option_t Option_t TPoint TPoint percent
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t gval
Option_t Option_t TPoint TPoint DrawText
Option_t Option_t TPoint TPoint SetOpacity
Option_t Option_t TPoint TPoint const char text
Option_t Option_t TPoint TPoint const char y1
char name[80]
Definition TGX11.cxx:148
Atom_t gMOTIF_WM_HINTS
Definition TVirtualX.cxx:35
TVirtualX * gGXBatch
Definition TVirtualX.cxx:39
Atom_t gROOT_MESSAGE
Definition TVirtualX.cxx:36
Atom_t gWM_DELETE_WINDOW
Definition TVirtualX.cxx:34
R__EXTERN TVirtualX *(* gPtr2VirtualX)()
Definition TVirtualX.h:378
Fill Area Attributes class.
Definition TAttFill.h:21
Line Attributes class.
Definition TAttLine.h:21
Marker Attributes class.
Definition TAttMarker.h:21
Text Attributes class.
Definition TAttText.h:21
virtual void SetTextAngle(Float_t tangle=0)
Set the text angle.
Definition TAttText.h:49
The TNamed class is the base class for all named ROOT classes.
Definition TNamed.h:29
SCoord_t fY
Definition TPoint.h:36
SCoord_t fX
Definition TPoint.h:35
Basic string class.
Definition TString.h:138
Semi-Abstract base class defining a generic interface to the underlying, low level,...
Definition TVirtualX.h:46
virtual void FillRectangle(Drawable_t id, GContext_t gc, Int_t x, Int_t y, UInt_t w, UInt_t h)
Fills the specified rectangle defined by [x,y] [x+w,y] [x+w,y+h] [x,y+h].
virtual Bool_t AllocColor(Colormap_t cmap, ColorStruct_t &color)
Allocates a read-only colormap entry corresponding to the closest RGB value supported by the hardware...
virtual Int_t WriteGIF(char *name)
Writes the current window into GIF file.
virtual void DestroyWindow(Window_t id)
Destroys the window "id" as well as all of its subwindows.
virtual Window_t CreateOpenGLWindow(Window_t parentID, UInt_t width, UInt_t height, const std::vector< std::pair< UInt_t, Int_t > > &format)
Create window with special pixel format. Noop everywhere except Cocoa.
virtual void CopyPixmapW(WinContext_t wctxt, Int_t wid, Int_t xpos, Int_t ypos)
Copy pixmap to specified window.
virtual void DispatchClientMessage(UInt_t messageID)
Force processing of event, sent by SendEvent before.
virtual void GetGCValues(GContext_t gc, GCValues_t &gval)
Returns the components specified by the mask in "gval" for the specified GC "gc" (see also the GCValu...
virtual Handle_t GetCurrentOpenGLContext()
Asks OpenGL subsystem about the current OpenGL context.
virtual void DrawPolyLine(Int_t n, TPoint *xy)
Draws a line through all points in the list.
virtual void SetWindowHint(Window_t id, EWindowHint hint)
Alters the property for the specified window and causes the X server to generate a PropertyNotify eve...
virtual void SetWindowBackground(Window_t id, ULong_t color)
Sets the background of the window "id" to the specified color value "color".
virtual Int_t KeysymToKeycode(UInt_t keysym)
Converts the "keysym" to the appropriate keycode.
virtual void SetPrimarySelectionOwner(Window_t id)
Makes the window "id" the current owner of the primary selection.
virtual void DeleteImage(Drawable_t img)
Deallocates the memory associated with the image img.
void SetFillColor(Color_t cindex) override
Sets color index "cindex" for fill areas.
void SetMarkerStyle(Style_t markerstyle) override
Sets marker style.
virtual void DrawLinesSegments(Int_t n, TPoint *xy)
Draws N segments between provided points.
virtual void SetWMTransientHint(Window_t id, Window_t main_id)
Tells window manager that the window "id" is a transient window of the window "main_id".
virtual void SetTextMagnitude(Float_t mgn)
Sets the current text magnification factor to "mgn".
virtual void GetWindowSize(Drawable_t id, Int_t &x, Int_t &overridey, UInt_t &w, UInt_t &h)
Returns the location and the size of window "id".
virtual void MapRaised(Window_t id)
Maps the window "id" and all of its subwindows that have had map requests on the screen and put this ...
virtual void SetOpacity(Int_t percent)
Sets opacity of the current window.
virtual void DeleteFont(FontStruct_t fs)
Explicitly deletes the font structure "fs" obtained via LoadQueryFont().
virtual Pixmap_t CreateBitmap(Drawable_t id, const char *bitmap, UInt_t width, UInt_t height)
Creates a bitmap (i.e.
virtual void ConvertSelection(Window_t, Atom_t &, Atom_t &, Atom_t &, Time_t &)
Requests that the specified selection be converted to the specified target type.
virtual void DrawLineW(WinContext_t wctxt, Int_t x1, Int_t y1, Int_t x2, Int_t y2)
Draw line on specified window.
virtual void GrabPointer(Window_t id, UInt_t evmask, Window_t confine, Cursor_t cursor, Bool_t grab=kTRUE, Bool_t owner_events=kTRUE)
Establishes an active pointer grab.
virtual void ChangeActivePointerGrab(Window_t, UInt_t, Cursor_t)
Changes the specified dynamic parameters if the pointer is actively grabbed by the client and if the ...
virtual EDrawMode GetDrawModeW(WinContext_t wctxt)
Returns window draw mode.
virtual Int_t OpenPixmap(UInt_t w, UInt_t h)
Creates a pixmap of the width "w" and height "h" you specified.
virtual void UnmapWindow(Window_t id)
Unmaps the specified window "id".
virtual void SetRGB(Int_t cindex, Float_t r, Float_t g, Float_t b)
Sets color intensities the specified color index "cindex".
virtual void FreeFontStruct(FontStruct_t fs)
Frees the font structure "fs".
virtual Int_t AddPixmap(ULongptr_t pixid, UInt_t w, UInt_t h)
Registers a pixmap created by TGLManager as a ROOT pixmap.
virtual void PutImage(Drawable_t id, GContext_t gc, Drawable_t img, Int_t dx, Int_t dy, Int_t x, Int_t y, UInt_t w, UInt_t h)
Combines an image with a rectangle of the specified drawable.
EDrawMode GetDrawMode()
Definition TVirtualX.h:153
virtual void FillPolygon(Window_t id, GContext_t gc, Point_t *points, Int_t npnt)
Fills the region closed by the specified path.
virtual FontStruct_t GetGCFont(GContext_t gc)
Return the font associated with the graphics context gc.
virtual void XorRegion(Region_t rega, Region_t regb, Region_t result)
Calculates the difference between the union and intersection of two regions.
virtual void SetClipOFF(Int_t wid)
Turns off the clipping for the window "wid".
virtual void FlushOpenGLBuffer(Handle_t ctx)
Flushes OpenGL buffer.
virtual void DeleteOpenGLContext(Int_t wid=0)
Deletes OpenGL context for window "wid".
virtual Colormap_t GetColormap() const
Returns handle to colormap.
virtual FontStruct_t LoadQueryFont(const char *font_name)
Provides the most common way for accessing a font: opens (loads) the specified font and returns a poi...
virtual void SetTypeList(Window_t win, Atom_t prop, Atom_t *typelist)
Add the list of drag and drop types to the Window win.
virtual void DeleteProperty(Window_t, Atom_t &)
Deletes the specified property only if the property was defined on the specified window and causes th...
virtual Bool_t HasTTFonts() const
Returns True when TrueType fonts are used.
virtual Cursor_t CreateCursor(ECursor cursor)
Creates the specified cursor.
virtual void LookupString(Event_t *event, char *buf, Int_t buflen, UInt_t &keysym)
Converts the keycode from the event structure to a key symbol (according to the modifiers specified i...
virtual void DrawLinesSegmentsW(WinContext_t wctxt, Int_t n, TPoint *xy)
Draw line segments on specified window.
virtual void GrabButton(Window_t id, EMouseButton button, UInt_t modifier, UInt_t evmask, Window_t confine, Cursor_t cursor, Bool_t grab=kTRUE)
Establishes a passive grab on a certain mouse button.
virtual void DrawFillAreaW(WinContext_t wctxt, Int_t n, TPoint *xy)
Draw fill area on specified window.
virtual void RaiseWindow(Window_t id)
Raises the specified window to the top of the stack so that no sibling window obscures it.
virtual Float_t GetTextMagnitude()
Returns the current font magnification factor.
virtual void SetWindowBackgroundPixmap(Window_t id, Pixmap_t pxm)
Sets the background pixmap of the window "id" to the specified pixmap "pxm".
virtual void GetCharacterUp(Float_t &chupx, Float_t &chupy)
Returns character up vector.
virtual void DrawPolyMarkerW(WinContext_t wctxt, Int_t n, TPoint *xy)
Draw poly marker on specified window.
virtual void SelectInput(Window_t id, UInt_t evmask)
Defines which input events the window is interested in.
virtual Display_t GetDisplay() const
Returns handle to display (might be useful in some cases where direct X11 manipulation outside of TVi...
virtual Bool_t EqualRegion(Region_t rega, Region_t regb)
Returns kTRUE if the two regions have the same offset, size, and shape.
virtual void SetAttMarker(WinContext_t wctxt, const TAttMarker &att)
Set marker attributes for specified window.
virtual void SetAttLine(WinContext_t wctxt, const TAttLine &att)
Set line attributes for specified window.
virtual Bool_t CreatePictureFromData(Drawable_t id, char **data, Pixmap_t &pict, Pixmap_t &pict_mask, PictureAttributes_t &attr)
Creates a picture pict from data in bitmap format.
virtual void SetIconPixmap(Window_t id, Pixmap_t pix)
Sets the icon name pixmap.
virtual Bool_t SetSelectionOwner(Window_t, Atom_t &)
Changes the owner and last-change time for the specified selection.
virtual void SetClipRegion(Int_t wid, Int_t x, Int_t y, UInt_t w, UInt_t h)
Sets clipping region for the window "wid".
virtual void GetImageSize(Drawable_t id, UInt_t &width, UInt_t &height)
Returns the width and height of the image id.
virtual Window_t GetDefaultRootWindow() const
Returns handle to the default root window created when calling XOpenDisplay().
virtual Bool_t EmptyRegion(Region_t reg)
Returns kTRUE if the region reg is empty.
virtual Int_t SupportsExtension(const char *ext) const
Returns 1 if window system server supports extension given by the argument, returns 0 in case extensi...
virtual void BeginModalSessionFor(Window_t window)
Start a modal session for a dialog window.
virtual void DeletePixmap(Pixmap_t pmap)
Explicitly deletes the pixmap resource "pmap".
virtual void SetClassHints(Window_t id, char *className, char *resourceName)
Sets the windows class and resource name.
virtual FontH_t GetFontHandle(FontStruct_t fs)
Returns the font handle of the specified font structure "fs".
virtual void DrawCellArray(Int_t x1, Int_t y1, Int_t x2, Int_t y2, Int_t nx, Int_t ny, Int_t *ic)
Draws a cell array.
virtual Bool_t Init(void *display=nullptr)
Initializes the X system.
virtual void ResizeWindow(Int_t wid)
Resizes the window "wid" if necessary.
virtual void SetDashes(GContext_t gc, Int_t offset, const char *dash_list, Int_t n)
Sets the dash-offset and dash-list attributes for dashed line styles in the specified GC.
virtual void SetAttFill(WinContext_t wctxt, const TAttFill &att)
Set fill attributes for specified window.
virtual void Warp(Int_t ix, Int_t iy, Window_t id=0)
Sets the pointer position.
virtual Int_t GetProperty(Window_t, Atom_t, Long_t, Long_t, Bool_t, Atom_t, Atom_t *, Int_t *, ULong_t *, ULong_t *, unsigned char **)
Returns the actual type of the property; the actual format of the property; the number of 8-bit,...
virtual void DrawRectangle(Drawable_t id, GContext_t gc, Int_t x, Int_t y, UInt_t w, UInt_t h)
Draws rectangle outlines of [x,y] [x+w,y] [x+w,y+h] [x,y+h].
virtual Drawable_t CreateImage(UInt_t width, UInt_t height)
Allocates the memory needed for an drawable.
virtual Int_t GetDoubleBuffer(Int_t wid)
Queries the double buffer value for the window "wid".
virtual void SetDoubleBuffer(Int_t wid, Int_t mode)
Sets the double buffer on/off on the window "wid".
virtual Int_t GetScreen() const
Returns screen number.
virtual void LowerWindow(Window_t id)
Lowers the specified window "id" to the bottom of the stack so that it does not obscure any sibling w...
virtual void CreateOpenGLContext(Int_t wid=0)
Creates OpenGL context for window "wid".
virtual void ClearArea(Window_t id, Int_t x, Int_t y, UInt_t w, UInt_t h)
Paints a rectangular area in the specified window "id" according to the specified dimensions with the...
virtual void MapSubwindows(Window_t id)
Maps all subwindows for the specified window "id" in top-to-bottom stacking order.
virtual void FreeFontNames(char **fontlist)
Frees the specified the array of strings "fontlist".
virtual Window_t GetInputFocus()
Returns the window id of the window having the input focus.
virtual void ClosePixmap()
Deletes current pixmap.
virtual void SetInputFocus(Window_t id)
Changes the input focus to specified window "id".
virtual void SetWMState(Window_t id, EInitialState state)
Sets the initial state of the window "id": either kNormalState or kIconicState.
virtual void Update(Int_t mode=0)
Flushes (mode = 0, default) or synchronizes (mode = 1) X output buffer.
virtual Int_t RequestLocator(Int_t mode, Int_t ctyp, Int_t &x, Int_t &y)
Requests Locator position.
virtual UInt_t ExecCommand(TGWin32Command *code)
Executes the command "code" coming from the other threads (Win32)
virtual void SendEvent(Window_t id, Event_t *ev)
Specifies the event "ev" is to be sent to the window "id".
virtual Int_t AddWindow(ULongptr_t qwid, UInt_t w, UInt_t h)
Registers a window created by Qt as a ROOT window.
virtual Int_t GetFontAscent() const
Returns the ascent of the current font (in pixels).
virtual void SetForeground(GContext_t gc, ULong_t foreground)
Sets the foreground color for the specified GC (shortcut for ChangeGC with only foreground mask set).
virtual void DrawBox(Int_t x1, Int_t y1, Int_t x2, Int_t y2, EBoxMode mode)
Draws a box between [x1,y1] and [x2,y2] according to the "mode".
virtual FontStruct_t GetFontStruct(FontH_t fh)
Retrieves the associated font structure of the font specified font handle "fh".
virtual Bool_t ReadPictureDataFromFile(const char *filename, char ***ret_data)
Reads picture data from file "filename" and store it in "ret_data".
virtual void SetDrawModeW(WinContext_t wctxt, EDrawMode mode)
Set window draw mode.
virtual void UpdateWindow(Int_t mode)
Updates or synchronises client and server once (not permanent).
virtual void SetCursor(Int_t win, ECursor cursor)
The cursor "cursor" will be used when the pointer is in the window "wid".
virtual void CopyGC(GContext_t org, GContext_t dest, Mask_t mask)
Copies the specified components from the source GC "org" to the destination GC "dest".
void SetFillStyle(Style_t style) override
Sets fill area style.
virtual void CloseWindow()
Deletes current window.
virtual void RescaleWindow(Int_t wid, UInt_t w, UInt_t h)
Rescales the window "wid".
virtual Int_t OpenDisplay(const char *dpyName)
Opens connection to display server (if such a thing exist on the current platform).
virtual Int_t SetTextFont(char *fontname, ETextSetMode mode)
Sets text font to specified name "fontname".This function returns 0 if the specified font is found,...
virtual Int_t RequestString(Int_t x, Int_t y, char *text)
Requests string: text is displayed and can be edited with Emacs-like keybinding.
virtual Int_t WriteGIFW(WinContext_t wctxt, const char *name)
Save specified window as GIF image.
virtual void GetTextExtent(UInt_t &w, UInt_t &h, char *mess)
Returns the size of the specified character string "mess".
virtual ULong_t GetPixel(Color_t cindex)
Returns pixel value associated to specified ROOT color number "cindex".
virtual void ChangeProperties(Window_t id, Atom_t property, Atom_t type, Int_t format, UChar_t *data, Int_t len)
Alters the property for the specified window and causes the X server to generate a PropertyNotify eve...
virtual void SetDNDAware(Window_t, Atom_t *)
Add XdndAware property and the list of drag and drop types to the Window win.
virtual void SetWMSizeHints(Window_t id, UInt_t wmin, UInt_t hmin, UInt_t wmax, UInt_t hmax, UInt_t winc, UInt_t hinc)
Gives the window manager minimum and maximum size hints of the window "id".
virtual void GetWindowAttributes(Window_t id, WindowAttributes_t &attr)
The WindowAttributes_t structure is set to default.
Definition TVirtualX.cxx:67
void SetTextSize(Float_t textsize) override
Sets the current text size to "textsize".
virtual Bool_t CreatePictureFromFile(Drawable_t id, const char *filename, Pixmap_t &pict, Pixmap_t &pict_mask, PictureAttributes_t &attr)
Creates a picture pict from data in file "filename".
virtual Bool_t ParseColor(Colormap_t cmap, const char *cname, ColorStruct_t &color)
Looks up the string name of a color "cname" with respect to the screen associated with the specified ...
Definition TVirtualX.cxx:90
virtual Int_t ResizePixmap(Int_t wid, UInt_t w, UInt_t h)
Resizes the specified pixmap "wid".
virtual Window_t FindRWindow(Window_t win, Window_t dragwin, Window_t input, int x, int y, int maxd)
Recursively search in the children of Window for a Window which is at location x, y and is DND aware,...
virtual void TranslateCoordinates(Window_t src, Window_t dest, Int_t src_x, Int_t src_y, Int_t &dest_x, Int_t &dest_y, Window_t &child)
Translates coordinates in one window to the coordinate space of another window.
virtual Double_t GetOpenGLScalingFactor()
On a HiDPI resolution it can be > 1., this means glViewport should use scaled width and height.
virtual void ReparentWindow(Window_t id, Window_t pid, Int_t x, Int_t y)
If the specified window is mapped, ReparentWindow automatically performs an UnmapWindow request on it...
virtual void DrawTextW(WinContext_t wctxt, Int_t x, Int_t y, Float_t angle, Float_t mgn, const char *text, ETextMode mode)
Draw text on specified window.
virtual void DrawSegments(Drawable_t id, GContext_t gc, Segment_t *seg, Int_t nseg)
Draws multiple line segments.
virtual void CloseDisplay()
Closes connection to display server and destroys all windows.
virtual void DeletePictureData(void *data)
Delete picture data created by the function ReadPictureDataFromFile.
static TVirtualX *& Instance()
Returns gVirtualX global.
Definition TVirtualX.cxx:57
virtual void UnionRegion(Region_t rega, Region_t regb, Region_t result)
Computes the union of two regions.
virtual void SetWindowName(Window_t id, char *name)
Sets the window name.
virtual void Bell(Int_t percent)
Sets the sound bell. Percent is loudness from -100% to 100%.
virtual void GetFontProperties(FontStruct_t font, Int_t &max_ascent, Int_t &max_descent)
Returns the font properties.
virtual Bool_t PointInRegion(Int_t x, Int_t y, Region_t reg)
Returns kTRUE if the point [x, y] is contained in the region reg.
virtual void CopyPixmap(Int_t wid, Int_t xpos, Int_t ypos)
Copies the pixmap "wid" at the position [xpos,ypos] in the current window.
virtual Pixmap_t CreatePixmap(Drawable_t id, UInt_t w, UInt_t h)
Creates a pixmap of the specified width and height and returns a pixmap ID that identifies it.
virtual void SetOpacityW(WinContext_t wctxt, Int_t percent)
Set opactity for specified window.
virtual Int_t GetFontDescent() const
Returns the descent of the current font (in pixels.
virtual void SetDoubleBufferOFF()
Turns double buffer mode off.
void SetLineColor(Color_t cindex) override
Sets color index "cindex" for drawing lines.
virtual void GetPlanes(Int_t &nplanes)
Returns the maximum number of planes.
virtual void SetKeyAutoRepeat(Bool_t on=kTRUE)
Turns key auto repeat on (kTRUE) or off (kFALSE).
virtual Bool_t GetFontAscentDescent(Font_t font, Double_t size, UInt_t &a, UInt_t &d, const char *mess)
Returns ascent/descent for specified character string "mess" with font and size.
void SetLineStyle(Style_t linestyle) override
Sets the line style.
virtual void DrawPolyMarker(Int_t n, TPoint *xy)
Draws "n" markers with the current attributes at position [x,y].
virtual void UpdateWindowW(WinContext_t wctxt, Int_t mode)
Update specified window.
virtual void SetWMSize(Window_t id, UInt_t w, UInt_t h)
Tells window manager the desired size of window "id".
virtual void ChangeWindowAttributes(Window_t id, SetWindowAttributes_t *attr)
Changes the attributes of the specified window "id" according the values provided in "attr".
virtual void GetRGB(Int_t index, Float_t &r, Float_t &g, Float_t &b)
Returns RGB values for color "index".
virtual void GetPasteBuffer(Window_t id, Atom_t atom, TString &text, Int_t &nchar, Bool_t del)
Gets contents of the paste buffer "atom" into the string "text".
virtual Handle_t GetNativeEvent() const
Returns the current native event handle.
virtual void DrawBoxW(WinContext_t wctxt, Int_t x1, Int_t y1, Int_t x2, Int_t y2, EBoxMode mode)
Draw box on specified window.
virtual void SetIconName(Window_t id, char *name)
Sets the window icon name.
virtual void Sync(Int_t mode)
Set synchronisation on or off.
virtual void SetClipRectangles(GContext_t gc, Int_t x, Int_t y, Rectangle_t *recs, Int_t n)
Sets clipping rectangles in graphics context.
void SetMarkerColor(Color_t cindex) override
Sets color index "cindex" for markers.
virtual void SetLineType(Int_t n, Int_t *dash)
Sets the line type.
virtual Region_t PolygonRegion(Point_t *points, Int_t np, Bool_t winding)
Returns a region for the polygon defined by the points array.
virtual void DestroySubwindows(Window_t id)
The DestroySubwindows function destroys all inferior windows of the specified window,...
virtual void SelectPixmap(Int_t qpixid)
Selects the pixmap "qpixid".
void SetTextAlign(Short_t talign=11) override
Sets the text alignment.
virtual Atom_t InternAtom(const char *atom_name, Bool_t only_if_exist)
Returns the atom identifier associated with the specified "atom_name" string.
virtual void WritePixmap(Int_t wid, UInt_t w, UInt_t h, char *pxname)
Writes the pixmap "wid" in the bitmap file "pxname".
virtual void UnionRectWithRegion(Rectangle_t *rect, Region_t src, Region_t dest)
Updates the destination region from a union of the specified rectangle and the specified source regio...
virtual void SetDoubleBufferON()
Turns double buffer mode on.
virtual void SetDrawMode(EDrawMode mode)
Sets the drawing mode.
virtual unsigned char * GetColorBits(Drawable_t wid, Int_t x=0, Int_t y=0, UInt_t w=0, UInt_t h=0)
Returns an array of pixels created from a part of drawable (defined by x, y, w, h) in format:
virtual void ChangeGC(GContext_t gc, GCValues_t *gval)
Changes the components specified by the mask in gval for the specified GC.
virtual const char * DisplayName(const char *=nullptr)
Returns hostname on which the display is opened.
virtual void ShapeCombineMask(Window_t id, Int_t x, Int_t y, Pixmap_t mask)
The Non-rectangular Window Shape Extension adds non-rectangular windows to the System.
virtual Bool_t GetTextExtentA(Font_t font, Double_t size, UInt_t &w, UInt_t &h, const char *mess)
Returns the size of the specified character string "mess" for font and size.
virtual void DrawText(Int_t x, Int_t y, Float_t angle, Float_t mgn, const char *text, ETextMode mode)
Draws a text string using current font.
virtual Window_t GetPrimarySelectionOwner()
Returns the window id of the current owner of the primary selection.
virtual void IconifyWindow(Window_t id)
Iconifies the window "id".
virtual Window_t GetCurrentWindow() const
pointer to the current internal window used in canvas graphics
void SetLineWidth(Width_t width) override
Sets the line width.
virtual void CopyArea(Drawable_t src, Drawable_t dest, GContext_t gc, Int_t src_x, Int_t src_y, UInt_t width, UInt_t height, Int_t dest_x, Int_t dest_y)
Combines the specified rectangle of "src" with the specified rectangle of "dest" according to the "gc...
virtual void MoveResizeWindow(Window_t id, Int_t x, Int_t y, UInt_t w, UInt_t h)
Changes the size and location of the specified window "id" without raising it.
virtual char ** ListFonts(const char *fontname, Int_t max, Int_t &count)
Returns list of font names matching fontname regexp, like "-*-times-*".
virtual void DeleteGC(GContext_t gc)
Deletes the specified GC "gc".
virtual void ChangeProperty(Window_t id, Atom_t property, Atom_t type, UChar_t *data, Int_t len)
Alters the property for the specified window and causes the X server to generate a PropertyNotify eve...
virtual void NextEvent(Event_t &event)
The "event" is set to default event.
virtual void FreeColor(Colormap_t cmap, ULong_t pixel)
Frees color cell with specified pixel value.
virtual void QueryPointer(Int_t &ix, Int_t &iy)
Returns the pointer position.
virtual WinContext_t GetWindowContext(Int_t wid)
Get window drawing context Should remain valid until window exists.
virtual void SetCharacterUp(Float_t chupx, Float_t chupy)
Sets character up vector.
virtual void QueryColor(Colormap_t cmap, ColorStruct_t &color)
Returns the current RGB value for the pixel in the "color" structure.
void SetTextColor(Color_t cindex) override
Sets the color index "cindex" for text.
virtual void GetGeometry(Int_t wid, Int_t &x, Int_t &y, UInt_t &w, UInt_t &h)
Returns position and size of window "wid".
virtual Pixmap_t CreatePixmapFromData(unsigned char *bits, UInt_t width, UInt_t height)
create pixmap from RGB data.
virtual void GetRegionBox(Region_t reg, Rectangle_t *rect)
Returns smallest enclosing rectangle.
virtual void RemoveWindow(ULongptr_t qwid)
Removes the created by Qt window "qwid".
virtual Window_t GetParent(Window_t id) const
Returns the parent of the window "id".
virtual void DrawFillArea(Int_t n, TPoint *xy)
Fills area described by the polygon.
virtual void SetWMPosition(Window_t id, Int_t x, Int_t y)
Tells the window manager the desired position [x,y] of window "id".
virtual void DrawString(Drawable_t id, GContext_t gc, Int_t x, Int_t y, const char *s, Int_t len)
Each character image, as defined by the font in the GC, is treated as an additional mask for a fill o...
virtual void MapGCFont(GContext_t, FontStruct_t)
Map the XftFont with the Graphics Context using it.
virtual void DrawPolyLineW(WinContext_t wctxt, Int_t n, TPoint *xy)
Draw poly line on specified window.
virtual void DestroyRegion(Region_t reg)
Destroys the region "reg".
virtual void SubtractRegion(Region_t rega, Region_t regb, Region_t result)
Subtracts regb from rega and stores the results in result.
virtual void GrabKey(Window_t id, Int_t keycode, UInt_t modifier, Bool_t grab=kTRUE)
Establishes a passive grab on the keyboard.
virtual Int_t EventsPending()
Returns the number of events that have been received from the X server but have not been removed from...
virtual GContext_t CreateGC(Drawable_t id, GCValues_t *gval)
Creates a graphics context using the provided GCValues_t *gval structure.
virtual Int_t InitWindow(ULongptr_t window)
Creates a new window and return window number.
virtual Bool_t MakeOpenGLContextCurrent(Handle_t ctx, Window_t windowID)
Makes context ctx current OpenGL context.
void SetMarkerSize(Float_t markersize) override
Sets marker size index.
virtual UInt_t ScreenWidthMM() const
Returns the width of the screen in millimeters.
virtual void SetAttText(WinContext_t wctxt, const TAttText &att)
Set text attributes for specified window.
virtual void DrawLine(Int_t x1, Int_t y1, Int_t x2, Int_t y2)
Draws a line.
virtual void ClearWindowW(WinContext_t wctxt)
Clear specified window.
virtual Bool_t NeedRedraw(ULongptr_t tgwindow, Bool_t force)
Notify the low level GUI layer ROOT requires "tgwindow" to be updated.
virtual Window_t CreateWindow(Window_t parent, Int_t x, Int_t y, UInt_t w, UInt_t h, UInt_t border, Int_t depth, UInt_t clss, void *visual, SetWindowAttributes_t *attr, UInt_t wtype)
Creates an unmapped subwindow for a specified parent window and returns the created window.
virtual Visual_t GetVisual() const
Returns handle to visual.
virtual Pixmap_t ReadGIF(Int_t x0, Int_t y0, const char *file, Window_t id=0)
If id is NULL - loads the specified gif file at position [x0,y0] in the current window.
virtual Bool_t IsDNDAware(Window_t win, Atom_t *typelist)
Checks if the Window is DND aware, and knows any of the DND formats passed in argument.
virtual Int_t TextWidth(FontStruct_t font, const char *s, Int_t len)
Return length of the string "s" in pixels. Size depends on font.
virtual void ClearWindow()
Clears the entire area of the current window.
virtual void SelectWindow(Int_t wid)
Selects the window "wid" to which subsequent output is directed.
virtual void PutPixel(Drawable_t id, Int_t x, Int_t y, ULong_t pixel)
Overwrites the pixel in the image with the specified pixel value.
virtual Int_t GetDepth() const
Returns depth of screen (number of bit planes).
virtual Window_t GetWindowID(Int_t wid)
Returns the X11 window identifier.
virtual Bool_t CheckEvent(Window_t id, EGEventType type, Event_t &ev)
Check if there is for window "id" an event of type "type".
virtual void ConvertPrimarySelection(Window_t id, Atom_t clipboard, Time_t when)
Causes a SelectionRequest event to be sent to the current primary selection owner.
virtual void MoveWindow(Int_t wid, Int_t x, Int_t y)
Moves the window "wid" to the specified x and y coordinates.
virtual void WMDeleteNotify(Window_t id)
Tells WM to send message when window is closed via WM.
virtual void IntersectRegion(Region_t rega, Region_t regb, Region_t result)
Computes the intersection of two regions.
virtual Region_t CreateRegion()
Creates a new empty region.
virtual void MapWindow(Window_t id)
Maps the window "id" and all of its subwindows that have had map requests.
virtual void SetMWMHints(Window_t id, UInt_t value, UInt_t funcs, UInt_t input)
Sets decoration style.
Double_t y[n]
Definition legend1.C:17
Double_t x[n]
Definition legend1.C:17
const Int_t n
Definition legend1.C:16
ULong_t fPixel
color pixel value (index in color table)
Definition GuiTypes.h:312
UShort_t fRed
red component (0..65535)
Definition GuiTypes.h:313
UShort_t fGreen
green component (0..65535)
Definition GuiTypes.h:314
UShort_t fBlue
blue component (0..65535)
Definition GuiTypes.h:315
UShort_t fMask
mask telling which color components are valid
Definition GuiTypes.h:316
Event structure.
Definition GuiTypes.h:175
Graphics context structure.
Definition GuiTypes.h:225
Point structure (maps to the X11 XPoint structure)
Definition GuiTypes.h:357
Rectangle structure (maps to the X11 XRectangle structure)
Definition GuiTypes.h:362
Used for drawing line segments (maps to the X11 XSegments structure)
Definition GuiTypes.h:352
Attributes that can be used when creating or changing a window.
Definition GuiTypes.h:94
Window attributes that can be inquired.
Definition GuiTypes.h:115