Logo ROOT  
Reference Guide
 
Loading...
Searching...
No Matches
TGX11TTF.cxx
Go to the documentation of this file.
1// @(#)root/x11ttf:$Id: 80028b538e60290371c1c5d73728f78b1c32f09a $
2// Author: Valeriy Onuchin (Xft support) 02/10/07
3// Author: Olivier Couet 01/10/02
4// Author: Fons Rademakers 21/11/98
5
6/*************************************************************************
7 * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers. *
8 * All rights reserved. *
9 * *
10 * For the licensing terms see $ROOTSYS/LICENSE. *
11 * For the list of contributors see $ROOTSYS/README/CREDITS. *
12 *************************************************************************/
13
14/** \class TGX11TTF
15\ingroup x11
16
17Interface to low level X11 (Xlib). This class gives access to basic
18X11 graphics via the parent class TGX11. However, all text and font
19handling is done via the Freetype TrueType library. When the
20shared library containing this class is loaded the global gVirtualX
21is redirected to point to this class.
22*/
23
24#include <cstdlib>
25
26#include <ft2build.h>
27#include FT_FREETYPE_H
28#include FT_GLYPH_H
29#include "TGX11TTF.h"
30#include "TEnv.h"
31
32#include <X11/Xlib.h>
33#include <X11/Xutil.h>
34#include <X11/Xatom.h>
35#include <X11/cursorfont.h>
36#include <X11/keysym.h>
37#include <X11/xpm.h>
38
39struct RXColor:XColor{};
40struct RVisual:Visual{};
41struct RXImage:XImage{};
42
43#ifdef R__HAS_XFT
44
45#include "THashTable.h"
46#include "TRefCnt.h"
47#include <X11/Xft/Xft.h>
48
49///////////////////////// xft font data //////////////////////////////////////
50class TXftFontData : public TNamed, public TRefCnt {
51public:
52 GContext_t fGC; // graphics context
53 XftFont *fXftFont; // xft font
54
57 {
58 SetRefCount(1);
59 fGC = gc;
60 }
61
62 void MapGCFont(GContext_t gc, FontStruct_t font)
63 {
64 fGC = gc; fXftFont = (XftFont *)font;
65 }
66
67 ~TXftFontData() override
68 {
69 if (References() == 1) {
70 if (fXftFont) XftFontClose((Display*)gVirtualX->GetDisplay(), fXftFont);
71 }
72 }
73};
74
75/////////////////// hash table //////////////////////////////////////////////
76class TXftFontHash {
77public:
78 THashTable *fList; // hash table
79
80 TXftFontHash() { fList = new THashTable(50); }
81
82 TXftFontData *FindByName(const char *name)
83 {
84 return (TXftFontData*)fList->FindObject(name);
85 }
86
88 {
89 TIter next(fList);
90
91 while (auto d = (TXftFontData*) next()) {
92 if (d->fXftFont == (XftFont *)font)
93 return d;
94 }
95 return nullptr;
96 }
97
99 {
100 TIter next(fList);
101
102 while (auto d = (TXftFontData*) next()) {
103 if (d->fGC == gc)
104 return d;
105 }
106 return nullptr;
107 }
108
109 void AddFont(TXftFontData *data)
110 {
111 // Loop over all existing TXftFontData, if we already have one with the same
112 // font data, set the reference counter of this one beyond 1 so it does
113 // delete the font pointer
114 TIter next(fList);
115
116 while (auto d = (TXftFontData*) next()) {
117 if (d->fXftFont == data->fXftFont)
118 data->AddReference();
119 }
120
121 fList->Add(data);
122 }
123
124 void FreeFont(TXftFontData *data)
125 {
126 fList->Remove(data);
127 delete data;
128 }
129};
130#endif // R__HAS_XFT
131
132/** \class TTFX11Init
133\ingroup GraphicsBackends
134
135Small utility class that takes care of switching the current
136gVirtualX to the new TGX11TTF class as soon as the shared library
137containing this class is loaded.
138*/
139
141public:
143};
145
146
147
148////////////////////////////////////////////////////////////////////////////////
149/// Create copy of TGX11 but now use TrueType fonts.
150
152{
153 SetName("X11TTF");
154 SetTitle("ROOT interface to X11 with TrueType fonts");
155
156 if (!TTF::fgInit) TTF::Init();
157
159 fHasXft = kFALSE;
160 fAlign.x = 0;
161 fAlign.y = 0;
162
163#ifdef R__HAS_XFT
164 fXftFontHash = nullptr;
165#endif
166}
167
168////////////////////////////////////////////////////////////////////////////////
169/// Static method setting TGX11TTF as the acting gVirtualX.
170
172{
173 if (gVirtualX && dynamic_cast<TGX11*>(gVirtualX)) {
174 TGX11 *oldg = (TGX11 *) gVirtualX;
175 gVirtualX = new TGX11TTF(*oldg);
176 delete oldg;
177 }
178}
179
180////////////////////////////////////////////////////////////////////////////////
181/// Initialize X11 system. Returns kFALSE in case of failure.
182
183Bool_t TGX11TTF::Init(void *display)
184{
185#ifdef R__HAS_XFT
186 fXftFontHash = nullptr;
187 XFontStruct *fs = nullptr;
188 if (display) fs = XLoadQueryFont((Display *)display, "-*-helvetica-*-r-*-*-14-*-*-*-*-*-*-*");
189 if (!fs) gEnv->SetValue("X11.UseXft", 1);
190 if (display && fs) XFreeFont((Display *)display, fs);
191 if (gEnv->GetValue("X11.UseXft", 0)) {
192 fHasXft = kTRUE;
194 }
195#endif
196 Bool_t r = TGX11::Init(display);
197
198 if (fDepth > 8) {
200 } else {
202 }
203
204 return r;
205}
206
207////////////////////////////////////////////////////////////////////////////////
208/// Compute alignment variables. The alignment is done on the horizontal string
209/// then the rotation is applied on the alignment variables.
210/// SetRotation and LayoutGlyphs should have been called before.
211
213{
214 EAlign align = (EAlign) fTextAlign;
215
216 // vertical alignment
217 if (align == kTLeft || align == kTCenter || align == kTRight) {
219 } else if (align == kMLeft || align == kMCenter || align == kMRight) {
220 fAlign.y = TTF::fgAscent/2;
221 } else {
222 fAlign.y = 0;
223 }
224
225 // horizontal alignment
226 if (align == kTRight || align == kMRight || align == kBRight) {
228 } else if (align == kTCenter || align == kMCenter || align == kBCenter) {
229 fAlign.x = TTF::fgWidth/2;
230 } else {
231 fAlign.x = 0;
232 }
233
235 fAlign.x = fAlign.x >> 6;
236 fAlign.y = fAlign.y >> 6;
237}
238
239////////////////////////////////////////////////////////////////////////////////
240/// Draw FT_Bitmap bitmap to xim image at position bx,by using specified
241/// foreground color.
242
245{
246 UChar_t d = 0, *s = source->buffer;
247
248 if (TTF::fgSmoothing) {
249
250 static RXColor col[5];
251 RXColor *bcol = nullptr;
252 XColor *bc;
253 Int_t x, y;
254
255 // background kClear, i.e. transparent, we take as background color
256 // the average of the rgb values of all pixels covered by this character
257 if (back == (ULong_t) -1 && (UInt_t)source->width) {
258 ULong_t r, g, b;
260 const Int_t maxdots = 50000;
261
262 dots = Int_t(source->width * source->rows);
263 dots = dots > maxdots ? maxdots : dots;
264 bcol = new RXColor[dots];
265 if (!bcol) return;
266 bc = bcol;
267 dotcnt = 0;
268 for (y = 0; y < (int) source->rows; y++) {
269 for (x = 0; x < (int) source->width; x++, bc++) {
270/// bc->pixel = XGetPixel(xim, bx + x, by - c->TTF::fgAscent + y);
271 bc->pixel = XGetPixel(xim, bx + x, by + y);
272 bc->flags = DoRed | DoGreen | DoBlue;
273 if (++dotcnt >= maxdots) break;
274 }
275 }
277 r = g = b = 0;
278 bc = bcol;
279 dotcnt = 0;
280 for (y = 0; y < (int) source->rows; y++) {
281 for (x = 0; x < (int) source->width; x++, bc++) {
282 r += bc->red;
283 g += bc->green;
284 b += bc->blue;
285 if (++dotcnt >= maxdots) break;
286 }
287 }
288 if (dots != 0) {
289 r /= dots;
290 g /= dots;
291 b /= dots;
292 }
293 bc = &col[0];
294 if (bc->red == r && bc->green == g && bc->blue == b)
295 bc->pixel = back;
296 else {
297 bc->pixel = ~back;
298 bc->red = (UShort_t) r;
299 bc->green = (UShort_t) g;
300 bc->blue = (UShort_t) b;
301 }
302 }
303 delete [] bcol;
304
305 // if fore or background have changed from previous character
306 // recalculate the 3 smoothing colors (interpolation between fore-
307 // and background colors)
308 if (fore != col[4].pixel || back != col[0].pixel) {
309 col[4].pixel = fore;
310 col[4].flags = DoRed|DoGreen|DoBlue;
311 if (back != (ULong_t) -1) {
312 col[3].pixel = back;
313 col[3].flags = DoRed | DoGreen | DoBlue;
314 QueryColors(fColormap, &col[3], 2);
315 col[0] = col[3];
316 } else {
317 QueryColors(fColormap, &col[4], 1);
318 }
319
320 // interpolate between fore and background colors
321 for (x = 3; x > 0; x--) {
322 col[x].red = (col[4].red *x + col[0].red *(4-x)) /4;
323 col[x].green = (col[4].green*x + col[0].green*(4-x)) /4;
324 col[x].blue = (col[4].blue *x + col[0].blue *(4-x)) /4;
325 if (!AllocColor(fColormap, &col[x])) {
326 Warning("DrawImage", "cannot allocate smoothing color");
327 col[x].pixel = col[x+1].pixel;
328 }
329 }
330 }
331
332 // put smoothed character, character pixmap values are an index
333 // into the 5 colors used for aliasing (4 = foreground, 0 = background)
334 for (y = 0; y < (int) source->rows; y++) {
335 for (x = 0; x < (int) source->width; x++) {
336 d = *s++ & 0xff;
337 d = ((d + 10) * 5) / 256;
338 if (d > 4) d = 4;
339 if (d && x < (int) source->width) {
340 ULong_t p = col[d].pixel;
341 XPutPixel(xim, bx + x, by + y, p);
342 }
343 }
344 }
345 } else {
346 // no smoothing, just put character using foreground color
347 UChar_t* row=s;
348 for (int y = 0; y < (int) source->rows; y++) {
349 int n = 0;
350 s = row;
351 for (int x = 0; x < (int) source->width; x++) {
352 if (n == 0) d = *s++;
353 if (TESTBIT(d,7-n))
354 XPutPixel(xim, bx + x, by + y, fore);
355 if (++n == (int) kBitsPerByte) n = 0;
356 }
357 row += source->pitch;
358 }
359 }
360}
361
362////////////////////////////////////////////////////////////////////////////////
363/// Draw text using TrueType fonts. If TrueType fonts are not available the
364/// text is drawn with TGX11::DrawText.
365
367 const char *text, ETextMode mode)
368{
369 if (!fHasTTFonts) {
371 } else {
372 if (!TTF::fgInit) TTF::Init();
376 Align();
377 RenderString(x, y, mode);
378 }
379}
380
381////////////////////////////////////////////////////////////////////////////////
382/// Draw text using TrueType fonts. If TrueType fonts are not available the
383/// text is drawn with TGX11::DrawText.
384
386 const wchar_t *text, ETextMode mode)
387{
388 if (!fHasTTFonts) {
390 } else {
391 if (!TTF::fgInit) TTF::Init();
395 Align();
396 RenderString(x, y, mode);
397 }
398}
399
400////////////////////////////////////////////////////////////////////////////////
401/// Get the background of the current window in an XImage.
402
404{
408 Int_t xy;
409 gVirtualX->GetWindowSize(cws, xy, xy, width, height);
410
411 if (x < 0) {
412 w += x;
413 x = 0;
414 }
415 if (y < 0) {
416 h += y;
417 y = 0;
418 }
419
420 if (x+w > width) w = width - x;
421 if (y+h > height) h = height - y;
422
423 return (RXImage*)XGetImage((Display*)fDisplay, cws, x, y, w, h, AllPlanes, ZPixmap);
424}
425
426////////////////////////////////////////////////////////////////////////////////
427/// Test if there is really something to render.
428
430{
434 Int_t xy;
435 gVirtualX->GetWindowSize(cws, xy, xy, width, height);
436
437 // If w or h is 0, very likely the string is only blank characters
438 if ((int)w == 0 || (int)h == 0) return kFALSE;
439
440 // If string falls outside window, there is probably no need to draw it.
441 if (x + (int)w <= 0 || x >= (int)width) return kFALSE;
442 if (y + (int)h <= 0 || y >= (int)height) return kFALSE;
443
444 // If w or h are much larger than the window size, there is probably no need
445 // to draw it. Moreover a to large text size may produce a Seg Fault in
446 // malloc in RenderString.
447 if (w > 10*width) return kFALSE;
448 if (h > 10*height) return kFALSE;
449
450 return kTRUE;
451}
452
453////////////////////////////////////////////////////////////////////////////////
454/// Perform the string rendering in the pad.
455/// LayoutGlyphs should have been called before.
456
458{
460
461 // compute the size and position of the XImage that will contain the text
462 Int_t Xoff = 0; if (TTF::GetBox().xMin < 0) Xoff = -TTF::GetBox().xMin;
463 Int_t Yoff = 0; if (TTF::GetBox().yMin < 0) Yoff = -TTF::GetBox().yMin;
464 Int_t w = TTF::GetBox().xMax + Xoff;
465 Int_t h = TTF::GetBox().yMax + Yoff;
466 Int_t x1 = x-Xoff-fAlign.x;
467 Int_t y1 = y+Yoff+fAlign.y-h;
468
469 if (!IsVisible(x1, y1, w, h)) return;
470
471 // create the XImage that will contain the text
473 XImage *xim = XCreateImage((Display*)fDisplay, fVisual,
474 depth, ZPixmap, 0, nullptr, w, h,
475 depth <= 8 ? 8 : (depth <= 16 ? 16 : 32), 0);
476 //bitmap_pad should be 8, 16 or 32 https://www.x.org/releases/X11R7.5/doc/man/man3/XPutPixel.3.html
477 if (!xim) return;
478
479 // use malloc since Xlib will use free() in XDestroyImage
480 xim->data = (char *) malloc(xim->bytes_per_line * h);
481 memset(xim->data, 0, xim->bytes_per_line * h);
482
483 ULong_t bg;
484 XGCValues values;
485 GC *gc = (GC*)GetGC(3);
486 if (!gc) {
487 Error("DrawText", "error getting Graphics Context");
488 return;
489 }
490 XGetGCValues((Display*)fDisplay, *gc, GCForeground | GCBackground, &values);
491
492 // get the background
493 if (mode == kClear) {
494 // if mode == kClear we need to get an image of the background
495 XImage *bim = GetBackground(x1, y1, w, h);
496 if (!bim) {
497 Error("DrawText", "error getting background image");
498 return;
499 }
500
501 // and copy it into the text image
502 Int_t xo = 0, yo = 0;
503 if (x1 < 0) xo = -x1;
504 if (y1 < 0) yo = -y1;
505
506 for (int yp = 0; yp < (int) bim->height; yp++) {
507 for (int xp = 0; xp < (int) bim->width; xp++) {
510 }
511 }
513 bg = (ULong_t) -1;
514 } else {
515 // if mode == kOpaque its simple, we just draw the background
516 XAddPixel(xim, values.background);
517 bg = values.background;
518 }
519
520 // paint the glyphs in the XImage
522 for (int n = 0; n < TTF::fgNumGlyphs; n++, glyph++) {
523 if (FT_Glyph_To_Bitmap(&glyph->fImage,
526 nullptr, 1 )) continue;
528 FT_Bitmap* source = &bitmap->bitmap;
529 Int_t bx, by;
530
531 bx = bitmap->left+Xoff;
532 by = h - bitmap->top-Yoff;
533 DrawImage(source, values.foreground, bg, (RXImage*)xim, bx, by);
534 }
535
536 // put the Ximage on the screen
538 gc = (GC*)GetGC(6);
539 if (gc) XPutImage((Display*)fDisplay, cws, *gc, xim, 0, 0, x1, y1, w, h);
541}
542
543////////////////////////////////////////////////////////////////////////////////
544/// Set specified font.
545
555
556////////////////////////////////////////////////////////////////////////////////
557/// Set text font to specified name.
558/// mode : loading flag
559/// mode=0 : search if the font exist (kCheck)
560/// mode=1 : search the font and load it if it exists (kLoad)
561/// font : font name
562///
563/// Set text font to specified name. This function returns 0 if
564/// the specified font is found, 1 if not.
565
567{
568 if (!fHasTTFonts) {
570 } else {
572 }
573}
574
575////////////////////////////////////////////////////////////////////////////////
576/// Set current text size.
577
587
588#ifdef R__HAS_XFT
589
590///////////////////////////// Xft font methods /////////////////////////////////
591////////////////////////////////////////////////////////////////////////////////
592/// Parses an XLFD name and opens a font.
593
594FontStruct_t TGX11TTF::LoadQueryFont(const char *font_name)
595{
596 if (!fXftFontHash) {
597 return TGX11::LoadQueryFont(font_name);
598 }
599
600 TXftFontData *data = fXftFontHash->FindByName(font_name);
601
602 // already loaded
603 if (data) {
604 return (FontStruct_t)data->fXftFont;
605 }
606
607 XftFont *xftfont = XftFontOpenXlfd((Display*)fDisplay, fScreenNumber, font_name);
608
609 data = new TXftFontData(0, xftfont, font_name);
610 fXftFontHash->AddFont(data);
611
612 return (FontStruct_t)xftfont;
613}
614
615////////////////////////////////////////////////////////////////////////////////
616/// Explicitly delete font structure obtained with LoadQueryFont().
617
619{
620 if (!fXftFontHash) {
622 return;
623 }
624
625 TXftFontData *data = fXftFontHash->FindByFont(fs);
626
627 if (data)
628 fXftFontHash->FreeFont(data);
629}
630
631////////////////////////////////////////////////////////////////////////////////
632/// Explicitly delete a graphics context.
633
635{
636 if (!fXftFontHash) {
638 return;
639 }
640
641 TXftFontData *gcdata = fXftFontHash->FindByGC(gc);
642 if (gcdata) fXftFontHash->FreeFont(gcdata);
644}
645
646////////////////////////////////////////////////////////////////////////////////
647/// Return handle to font described by font structure.
648
650{
651 if (!fXftFontHash) {
652 return TGX11::GetFontHandle(fs);
653 }
654
655 return (FontH_t)fs;
656}
657
658////////////////////////////////////////////////////////////////////////////////
659/// Return the font associated with the graphics context gc
660
662{
663 if (!fXftFontHash) {
664 return 0;
665 }
666
667 TXftFontData *data = fXftFontHash->FindByGC(gc);
668
669 // no XftFont data
670 if (!data) return 0;
671
672 return (FontStruct_t)data->fXftFont;
673}
674
675////////////////////////////////////////////////////////////////////////////////
676/// Map the XftFont with the Graphics Context using it.
677
679{
680 if (!fXftFontHash)
681 return;
682
683 TXftFontData *gcdata = fXftFontHash->FindByGC(gc);
684 TXftFontData *fontdata = fXftFontHash->FindByFont(font);
685
686 if (gcdata) { // && (gcdata->fXftFont == 0)) {
687 gcdata->fXftFont = (XftFont *)font;
688 }
689 else if (fontdata) {
690 TXftFontData *data = new TXftFontData(gc, (XftFont *)font, fontdata->GetName());
691 fXftFontHash->AddFont(data);
692 }
693}
694
695////////////////////////////////////////////////////////////////////////////////
696/// Return length of string in pixels. Size depends on font
697
698Int_t TGX11TTF::TextWidth(FontStruct_t font, const char *s, Int_t len)
699{
700 if (!fXftFontHash) {
701 return TGX11::TextWidth(font, s, len);
702 }
703
704 TXftFontData *data = fXftFontHash->FindByFont(font);
705
706 if (!data) return 0;
707
708 XftFont *xftfont = data->fXftFont;
709
710 if (xftfont) {
713 return glyph_info.xOff;
714 }
715 return 0;
716}
717
718////////////////////////////////////////////////////////////////////////////////
719/// Return some font properties
720
722{
723 if (!fXftFontHash) {
725 return;
726 }
727
728 TXftFontData *data = fXftFontHash->FindByFont(font);
729
730 if (!data) {
732 return;
733 }
734
735 XftFont *xftfont = data->fXftFont;
736
737 if (!xftfont) {
739 return;
740 }
741
742 max_ascent = xftfont->ascent;
743 max_descent = xftfont->descent;
744}
745
746////////////////////////////////////////////////////////////////////////////////
747/// Draw text string
748
750 const char *text, Int_t len)
751{
756
757 if (!xwindow) {
758 return;
759 }
760
761 if (!gc) {
762 return;
763 }
764
765 if (!text || (len < 1) || !text[0]) {
766 return;
767 }
768
769 if (!fXftFontHash) {
771 return;
772 }
773
775 gval.fMask = kGCForeground | kGCBackground; // retrieve GC values
777
778 TXftFontData *data = fXftFontHash->FindByGC(gc);
779
780 // no XftFont data
781 if (!data) {
783 return;
784 }
785
786 xftfont = data->fXftFont;
787
788 // no Xft font
789 if (!xftfont) {
791 return;
792 }
793
794 // dummies
796 Int_t dx,dy;
798
799 // check if drawable is bitmap
800 XGetGeometry((Display*)fDisplay, (Drawable)xwindow, &droot, &dx, &dy,
801 &width, &height, &bwidth, &depth);
802
803 if (depth <= 1) {
805 return;
806 }
807
808 memset(&xcolor, 0, sizeof(xcolor));
809 xcolor.pixel = gval.fForeground;
810
811 XQueryColor((Display*)fDisplay, fColormap, &xcolor);
812
813 // create XftDraw
815
816 if (!xftdraw) {
817 //Warning("could not create an XftDraw");
819 return;
820 }
821
822 xftcolor.color.red = xcolor.red;
823 xftcolor.color.green = xcolor.green;
824 xftcolor.color.blue = xcolor.blue;
825 xftcolor.color.alpha = 0xffff;
826 xftcolor.pixel = gval.fForeground;
827
829
830 // cleanup
832}
833
834#endif // R__HAS_XFT
const Mask_t kGCBackground
Definition GuiTypes.h:289
const Mask_t kGCForeground
Definition GuiTypes.h:288
Handle_t FontH_t
Font handle (as opposed to Font_t which is an index)
Definition GuiTypes.h:35
Handle_t Window_t
Window handle.
Definition GuiTypes.h:29
Handle_t GContext_t
Graphics context handle.
Definition GuiTypes.h:38
Handle_t Drawable_t
Drawable handle.
Definition GuiTypes.h:31
Handle_t FontStruct_t
Pointer to font structure.
Definition GuiTypes.h:39
#define d(i)
Definition RSha256.hxx:102
#define b(i)
Definition RSha256.hxx:100
#define g(i)
Definition RSha256.hxx:105
#define h(i)
Definition RSha256.hxx:106
unsigned short UShort_t
Unsigned Short integer 2 bytes (unsigned short)
Definition RtypesCore.h:54
int Int_t
Signed integer 4 bytes (int)
Definition RtypesCore.h:59
constexpr ULong_t kBitsPerByte
Definition RtypesCore.h:130
unsigned long ULong_t
Unsigned long integer 4 bytes (unsigned long). Size depends on architecture.
Definition RtypesCore.h:69
unsigned int UInt_t
Unsigned integer 4 bytes (unsigned int)
Definition RtypesCore.h:60
float Float_t
Float 4 bytes (float)
Definition RtypesCore.h:71
short Font_t
Font number (short)
Definition RtypesCore.h:95
constexpr Bool_t kFALSE
Definition RtypesCore.h:108
constexpr Bool_t kTRUE
Definition RtypesCore.h:107
#define TESTBIT(n, i)
Definition Rtypes.h:94
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
R__EXTERN TEnv * gEnv
Definition TEnv.h:170
winID h TVirtualViewer3D TVirtualGLPainter p
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void data
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 GetGCValues
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void pixel
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 fontnumber
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 GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char Pixmap_t Pixmap_t PictureAttributes_t attr const char char ret_data h unsigned char height h Atom_t Int_t ULong_t ULong_t unsigned char prop_list Atom_t Atom_t Atom_t Time_t UChar_t len
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 GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char bitmap
Option_t Option_t TPoint TPoint const char x1
Option_t Option_t textsize
Option_t Option_t TPoint TPoint angle
Option_t Option_t TPoint xy
Option_t Option_t TPoint TPoint const char mode
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 org
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 GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char fontname
Option_t Option_t width
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize fs
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 const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t height
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void gc
Option_t Option_t TPoint TPoint const char text
Option_t Option_t TPoint TPoint const char y1
static TTFX11Init gTTFX11Init
Definition TGX11TTF.cxx:144
char name[80]
Definition TGX11.cxx:110
XID Window
Definition TGX11.h:36
XID Drawable
Definition TGX11.h:33
#define gVirtualX
Definition TVirtualX.h:337
#define malloc
Definition civetweb.c:1575
Font_t fTextFont
Text font.
Definition TAttText.h:27
Float_t fTextSize
Text size.
Definition TAttText.h:24
virtual Int_t GetValue(const char *name, Int_t dflt) const
Returns the integer value for a resource.
Definition TEnv.cxx:490
virtual void SetValue(const char *name, const char *value, EEnvLevel level=kEnvChange, const char *type=nullptr)
Set the value of a resource or create a new resource.
Definition TEnv.cxx:735
void RenderString(Int_t x, Int_t y, ETextMode mode)
Perform the string rendering in the pad.
Definition TGX11TTF.cxx:457
static void Activate()
Static method setting TGX11TTF as the acting gVirtualX.
Definition TGX11TTF.cxx:171
void Align(void)
Compute alignment variables.
Definition TGX11TTF.cxx:212
RXImage * GetBackground(Int_t x, Int_t y, UInt_t w, UInt_t h)
Get the background of the current window in an XImage.
Definition TGX11TTF.cxx:403
Bool_t Init(void *display) override
Initialize X11 system. Returns kFALSE in case of failure.
Definition TGX11TTF.cxx:183
void SetTextSize(Float_t textsize) override
Set current text size.
Definition TGX11TTF.cxx:578
void DrawImage(FT_Bitmap *source, ULong_t fore, ULong_t back, RXImage *xim, Int_t bx, Int_t by)
Draw FT_Bitmap bitmap to xim image at position bx,by using specified foreground color.
Definition TGX11TTF.cxx:243
FT_Vector fAlign
alignment vector
Definition TGX11TTF.h:33
void SetTextFont(Font_t fontnumber) override
Set specified font.
Definition TGX11TTF.cxx:546
TGX11TTF(const TGX11 &org)
Create copy of TGX11 but now use TrueType fonts.
Definition TGX11TTF.cxx:151
Bool_t IsVisible(Int_t x, Int_t y, UInt_t w, UInt_t h)
Test if there is really something to render.
Definition TGX11TTF.cxx:429
@ kTCenter
Definition TGX11TTF.h:30
@ kBRight
Definition TGX11TTF.h:31
@ kBCenter
Definition TGX11TTF.h:31
@ kMCenter
Definition TGX11TTF.h:30
@ kMRight
Definition TGX11TTF.h:30
@ kTRight
Definition TGX11TTF.h:30
void DrawText(Int_t x, Int_t y, Float_t angle, Float_t mgn, const char *text, ETextMode mode) override
Draw text using TrueType fonts.
Definition TGX11TTF.cxx:366
This class is the basic interface to the X11 (Xlib) graphics system.
Definition TGX11.h:80
void * fDisplay
Pointer to display.
Definition TGX11.h:125
Colormap fColormap
Default colormap, 0 if b/w.
Definition TGX11.h:129
FontStruct_t LoadQueryFont(const char *font_name) override
Load font and query font.
Definition GX11Gui.cxx:941
Int_t fScreenNumber
Screen number.
Definition TGX11.h:132
Bool_t AllocColor(Colormap cmap, RXColor *color)
Allocate color in colormap.
Definition TGX11.cxx:365
void DrawText(Int_t x, Int_t y, Float_t angle, Float_t mgn, const char *text, ETextMode mode) override
Draw a text string using current font.
Definition TGX11.cxx:750
void QueryColors(Colormap cmap, RXColor *colors, Int_t ncolors)
Returns the current RGB value for the pixel in the XColor structure.
Definition TGX11.cxx:382
void * GetGC(Int_t which) const
Return desired Graphics Context ("which" maps directly on gGCList[]).
Definition TGX11.cxx:930
Bool_t fHasXft
True when XftFonts are used.
Definition TGX11.h:147
Int_t SetTextFont(char *fontname, ETextSetMode mode) override
Set text font to specified name.
Definition TGX11.cxx:3153
Int_t fTextAlign
Text alignment (set in SetTextAlign)
Definition TGX11.h:135
Int_t fDepth
Number of color planes.
Definition TGX11.h:139
Bool_t Init(void *display) override
Initialize X11 system. Returns kFALSE in case of failure.
Definition TGX11.cxx:341
void DeleteGC(GContext_t gc) override
Explicitly delete a graphics context.
Definition GX11Gui.cxx:1032
void SetTextSize(Float_t textsize) override
Set current text size.
Definition TGX11.cxx:3202
void DeleteFont(FontStruct_t fs) override
Explicitly delete font structure obtained with LoadQueryFont().
Definition GX11Gui.cxx:962
Int_t TextWidth(FontStruct_t font, const char *s, Int_t len) override
Return length of string in pixels. Size depends on font.
Definition GX11Gui.cxx:2069
FontH_t GetFontHandle(FontStruct_t fs) override
Return handle to font described by font structure.
Definition GX11Gui.cxx:950
void DrawString(Drawable_t id, GContext_t gc, Int_t x, Int_t y, const char *s, Int_t len) override
Draw a string using a specific graphics context in position (x,y).
Definition GX11Gui.cxx:2058
RVisual * fVisual
Pointer to visual used by all windows.
Definition TGX11.h:126
Window_t GetCurrentWindow() const override
Return current window pointer. Protected method used by TGX11TTF.
Definition TGX11.cxx:921
void GetFontProperties(FontStruct_t font, Int_t &max_ascent, Int_t &max_descent) override
Return some font properties.
Definition GX11Gui.cxx:2077
Bool_t fHasTTFonts
True when TrueType fonts are used.
Definition TGX11.h:146
THashTable implements a hash table to store TObject's.
Definition THashTable.h:35
void Add(TObject *obj) override
Add object to the hash table.
TObject * Remove(TObject *obj) override
Remove object from the hashtable.
TObject * FindObject(const char *name) const override
Find object using its name.
The TNamed class is the base class for all named ROOT classes.
Definition TNamed.h:29
virtual void SetTitle(const char *title="")
Set the title of the TNamed.
Definition TNamed.cxx:173
virtual void SetName(const char *name)
Set the name of the TNamed.
Definition TNamed.cxx:149
virtual void Warning(const char *method, const char *msgfmt,...) const
Issue warning message.
Definition TObject.cxx:1057
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
Definition TObject.cxx:1071
Definitions for TRefCnt, base class for reference counted objects.
Definition TRefCnt.h:27
Small utility class that takes care of switching the current gVirtualX to the new TGX11TTF class as s...
Definition TGX11TTF.cxx:140
TTF helper class containing glyphs description.
Definition TTF.h:65
static void PrepareString(const char *string)
Put the characters in "string" in the "glyphs" array.
Definition TTF.cxx:271
static TTF::TTGlyph fgGlyphs[kMaxGlyphs]
glyphs
Definition TTF.h:83
static Bool_t fgSmoothing
use anti-aliasing (true when >8 planes, false otherwise)
Definition TTF.h:90
static void Init()
Initialise the TrueType fonts interface.
Definition TTF.cxx:64
static void LayoutGlyphs()
Compute the glyphs positions, fgAscent and fgWidth (needed for alignment).
Definition TTF.cxx:202
static void SetSmoothing(Bool_t state)
Set smoothing (anti-aliasing) flag.
Definition TTF.cxx:370
static void SetRotationMatrix(Float_t angle)
Set the rotation matrix used to rotate the font outlines.
Definition TTF.cxx:347
static void SetTextFont(Font_t fontnumber)
Set specified font.
Definition TTF.cxx:495
static Int_t fgAscent
string ascent, used to compute Y alignment
Definition TTF.h:75
static Int_t fgWidth
string width, used to compute X alignment
Definition TTF.h:92
static Bool_t fgInit
true if the Init has been called
Definition TTF.h:85
static const FT_BBox & GetBox()
Definition TTF.cxx:656
static Int_t fgNumGlyphs
number of glyphs in the string
Definition TTF.h:88
static FT_Matrix * fgRotMatrix
rotation matrix
Definition TTF.h:89
static void SetTextSize(Float_t textsize)
Set current text size.
Definition TTF.cxx:566
virtual void DeleteFont(FontStruct_t fs)
Explicitly deletes the font structure "fs" obtained via LoadQueryFont().
virtual FontStruct_t GetGCFont(GContext_t gc)
Return the font associated with the graphics context gc.
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 FontH_t GetFontHandle(FontStruct_t fs)
Returns the font handle of the specified font structure "fs".
virtual void GetFontProperties(FontStruct_t font, Int_t &max_ascent, Int_t &max_descent)
Returns the font properties.
virtual void DeleteGC(GContext_t gc)
Deletes the specified GC "gc".
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 Int_t TextWidth(FontStruct_t font, const char *s, Int_t len)
Return length of the string "s" in pixels. Size depends on font.
Double_t y[n]
Definition legend1.C:17
Double_t x[n]
Definition legend1.C:17
const Int_t n
Definition legend1.C:16
Graphics context structure.
Definition GuiTypes.h:224