60#define FONT_UNDERLINE  4 
   61#define FONT_OVERSTRIKE 5 
   62#define FONT_NUMFIELDS  6 
   71#define XLFD_SETWIDTH       4 
   72#define XLFD_ADD_STYLE      5 
   73#define XLFD_PIXEL_SIZE     6 
   74#define XLFD_POINT_SIZE     7 
   75#define XLFD_RESOLUTION_X   8 
   76#define XLFD_RESOLUTION_Y   9 
   77#define XLFD_SPACING        10 
   78#define XLFD_AVERAGE_WIDTH  11 
   79#define XLFD_REGISTRY       12 
   80#define XLFD_ENCODING       13 
   81#define XLFD_NUMFIELDS      14    
   97   Int_t fNumDisplayChars; 
 
  120struct XLFDAttributes_t {
 
  122   const char *fFoundry; 
 
  144   Int_t            fDeletePending; 
 
  184struct FontStateMap_t { 
Int_t fNumKey; 
const char *fStrKey; };
 
  255   0, 0, 0, 0, 0, 0, 0, 
'a', 
'b', 
't', 
'n', 
'v', 
'f', 
'r', 0
 
  277      Error(
"GetFontMetrics", 
"argument may not be 0");
 
  301      Printf(
"TGFont: %s, %s, ref cnt = %u",
 
  346   if (strncasecmp(family, 
"itc ", 4) == 0) {
 
  349   if ((strcasecmp(family, 
"Arial") == 0)
 
  350       || (strcasecmp(family, 
"Geneva") == 0)) {
 
  351      family = 
"Helvetica";
 
  352   } 
else if ((strcasecmp(family, 
"Times New Roman") == 0)
 
  353              || (strcasecmp(family, 
"New York") == 0)) {
 
  355   } 
else if ((strcasecmp(family, 
"Courier New") == 0)
 
  356              || (strcasecmp(family, 
"Monaco") == 0)) {
 
  358   } 
else if (strcasecmp(family, 
"AvantGarde") == 0) {
 
  359      family = 
"AvantGarde";
 
  360   } 
else if (strcasecmp(family, 
"ZapfChancery") == 0) {
 
  361      family = 
"ZapfChancery";
 
  362   } 
else if (strcasecmp(family, 
"ZapfDingbats") == 0) {
 
  363      family = 
"ZapfDingbats";
 
  373      src = 
dest = (
char*)dst->
Data() + len;
 
  375      for (; *src != 
'\0'; src++, 
dest++) {
 
  376         while (isspace(
UChar_t(*src))) {
 
  381         if ((upper != 0) && (islower(
UChar_t(*src)))) {
 
  388      family = (
char *) dst->
Data() + len;
 
  390   if (family != (
char *) dst->
Data() + len) {
 
  392      family = (
char *) dst->
Data() + len;
 
  394   if (strcasecmp(family, 
"NewCenturySchoolbook") == 0) {
 
  396      dst->
Append(
"NewCenturySchlbk");
 
  397      family = (
char *) dst->
Data() + len;
 
  404      if (strcmp(family, 
"Bookman") == 0) {
 
  405         weightString = 
"Light";
 
  406      } 
else if (strcmp(family, 
"AvantGarde") == 0) {
 
  407         weightString = 
"Book";
 
  408      } 
else if (strcmp(family, 
"ZapfChancery") == 0) {
 
  409         weightString = 
"Medium";
 
  412      if ((strcmp(family, 
"Bookman") == 0)
 
  413           || (strcmp(family, 
"AvantGarde") == 0)) {
 
  414         weightString = 
"Demi";
 
  416         weightString = 
"Bold";
 
  426      if ((strcmp(family, 
"Helvetica") == 0)
 
  427           || (strcmp(family, 
"Courier") == 0)
 
  428           || (strcmp(family, 
"AvantGarde") == 0)) {
 
  429         slantString = 
"Oblique";
 
  431         slantString = 
"Italic";
 
  438   if ((slantString.
IsNull()) && (weightString.
IsNull())) {
 
  439      if ((strcmp(family, 
"Times") == 0)
 
  440           || (strcmp(family, 
"NewCenturySchlbk") == 0)
 
  441           || (strcmp(family, 
"Palatino") == 0)) {
 
  490   if (maxLength <= 0) {
 
  493   newX = curX = termX = 0;
 
  495   sawNonSpace = !isspace(
UChar_t(*p));
 
  501      if (newX > maxLength) {
 
  527   if ((flags & 
kTextPartialOK) && (numChars > 0) && (curX < maxLength)) {
 
  540      if (term == source) {
 
  550   return term - source;
 
  568      numChars = strlen(
string);
 
  583      numChars = strlen(
string);
 
  653   const char *start, *end, *special;
 
  654   Int_t n, 
y=0, charsThisChunk, maxChunks;
 
  655   Int_t baseline, 
h, curX, newX, maxWidth;
 
  657   LayoutChunk_t *chunk;
 
  662   Int_t maxLines, curLine, layoutHeight;
 
  664   lineLengths = staticLineLengths;
 
  670      numChars = strlen(
string);
 
  675   layout->
fFont = 
this;
 
  687   end = 
string + numChars;
 
  694   for (start = 
string; start < end;) {
 
  695      if (start >= special) {
 
  698         for (special = start; special < end; special++) {
 
  700               if ((*special == 
'\n') || (*special == 
'\r')) {
 
  705               if (*special == 
'\t') {
 
  716      if (start < special) {
 
  718                                       wrapLength - curX, flags, &newX);
 
  720         flags &= ~kTextAtLeastOne;
 
  721         if (charsThisChunk > 0) {
 
  722            chunk = 
NewChunk(layout, &maxChunks, start,
 
  723                             charsThisChunk, curX, newX, baseline);
 
  725            start += charsThisChunk;
 
  729      if ((start == special) && (special < end)) {
 
  731         LayoutChunk_t *newchunk = 0;
 
  734         if (*special == 
'\t') {
 
  737            newchunk = 
NewChunk(layout, &maxChunks, start, 1, curX, newX, baseline);
 
  738            if (newchunk) newchunk->fNumDisplayChars = -1;
 
  740            if ((start < end) && ((wrapLength <= 0) || (newX <= wrapLength))) {
 
  745               flags &= ~kTextAtLeastOne;
 
  749            newchunk = 
NewChunk(layout, &maxChunks, start, 1, curX, 1000000000, baseline);
 
  750            if (newchunk) newchunk->fNumDisplayChars = -1;
 
  760      while ((start < end) && isspace(
UChar_t(*start))) {
 
  762            if ((*start == 
'\n') || (*start == 
'\r')) {
 
  767            if (*start == 
'\t') {
 
  777         charsThisChunk = start - (chunk->fStart + chunk->fNumChars);
 
  778         if (charsThisChunk > 0) {
 
  779            chunk->fNumChars += 
MeasureChars(chunk->fStart + chunk->fNumChars,
 
  780                                             charsThisChunk, 0, 0, &chunk->fTotalWidth);
 
  781            chunk->fTotalWidth += curX;
 
  790      if (curX > maxWidth) {
 
  797      if (curLine >= maxLines) {
 
  800         newLengths = 
new int[2 * maxLines];
 
  801         memcpy((
void *) newLengths, lineLengths, maxLines * 
sizeof (
int));
 
  803         if (lineLengths != staticLineLengths) {
 
  804            delete[] lineLengths;
 
  806         lineLengths = newLengths;
 
  809      lineLengths[curLine] = curX;
 
  822         chunk = 
NewChunk(layout, &maxChunks, start, 0, curX, 1000000000, baseline);
 
  823         chunk->fNumDisplayChars = -1;
 
  833   if (chunk) 
y = chunk->fY;
 
  837      if (chunk->fY != 
y) {
 
  841      extra = maxWidth - lineLengths[curLine];
 
  843         chunk->fX += extra / 2;
 
  850   layout->
fWidth = maxWidth;
 
  860      layout->
fChunks = 
new LayoutChunk_t[1];
 
  861      layout->
fChunks[0].fStart = string;
 
  862      layout->
fChunks[0].fNumChars = 0;
 
  863      layout->
fChunks[0].fNumDisplayChars = -1;
 
  866      layout->
fChunks[0].fTotalWidth = 0;
 
  867      layout->
fChunks[0].fDisplayWidth = 0;
 
  873      *height = layoutHeight;
 
  875   if (lineLengths != staticLineLengths) {
 
  876      delete[] lineLengths;
 
  911   Int_t i, numDisplayChars, drawX;
 
  912   LayoutChunk_t *chunk;
 
  914   if (lastChar < 0) lastChar = 100000000;
 
  918      numDisplayChars = chunk->fNumDisplayChars;
 
  919      if ((numDisplayChars > 0) && (firstChar < numDisplayChars)) {
 
  920         if (firstChar <= 0) {
 
  926         if (lastChar < numDisplayChars) numDisplayChars = lastChar;
 
  927         fFont->
DrawChars(dst, gc, chunk->fStart + firstChar, numDisplayChars - firstChar,
 
  928                           x + chunk->fX + drawX, 
y + chunk->fY);
 
  930      firstChar -= chunk->fNumChars;
 
  931      lastChar -= chunk->fNumChars;
 
  933      if (lastChar <= 0) 
break;
 
  958   int xx, yy, 
width, height;
 
  990   LayoutChunk_t *chunk, *last;
 
 1004      baseline = chunk->fY;
 
 1005      if (y < baseline + fFont->fFM.fDescent) {
 
 1006         if (x < chunk->fX) {
 
 1010            return (chunk->fStart - 
fString);
 
 1026         while ((i < 
fNumChunks) && (chunk->fY == baseline)) {
 
 1027            if (x < chunk->fX + chunk->fTotalWidth) {
 
 1031               if (chunk->fNumDisplayChars < 0) {
 
 1036                  return (chunk->fStart - 
fString);
 
 1040               return ((chunk->fStart + 
n - 1) - 
fString);
 
 1051         pos = (last->fStart + last->fNumChars) - 
fString;
 
 1062   return ((last->fStart + last->fNumChars) - 
fString);
 
 1096   LayoutChunk_t *chunk;
 
 1097   Int_t i, xx = 0, ww = 0;
 
 1106      if (chunk->fNumDisplayChars < 0) {
 
 1109            ww = chunk->fTotalWidth;
 
 1112      } 
else if (index < chunk->fNumChars) {
 
 1122      index -= chunk->fNumChars;
 
 1130      xx = chunk->fX + chunk->fTotalWidth;
 
 1178   Int_t i, 
x1, 
x2, y1, y2, xDiff, yDiff, 
dist, minDist, ascent, descent;
 
 1179   LayoutChunk_t *chunk;
 
 1187      if (chunk->fStart[0] == 
'\n') {
 
 1196      y1 = chunk->fY - ascent;
 
 1197      x2 = chunk->fX + chunk->fDisplayWidth;
 
 1198      y2 = chunk->fY + descent;
 
 1202      } 
else if (
x >= 
x2) {
 
 1210      } 
else if (
y >= y2) {
 
 1215      if ((xDiff == 0) && (yDiff == 0)) {
 
 1219      if ((
dist < minDist) || !minDist) {
 
 1245   LayoutChunk_t *chunk;
 
 1246   Int_t left, top, right, bottom;
 
 1262      if (chunk->fStart[0] == 
'\n') {
 
 1272      x2 = chunk->fX + chunk->fDisplayWidth;
 
 1275      if ((right < 
x1) || (left >= 
x2) || (bottom < y1) || (top >= y2)) {
 
 1280      } 
else if ((
x1 < left) || (
x2 >= right) || (y1 < top) || (y2 >= bottom)) {
 
 1282      } 
else if (result == -1) {
 
 1323   LayoutChunk_t *chunk;
 
 1324   Int_t i, j, used, 
c, baseline;
 
 1327   baseline = chunk->fY;
 
 1332      if (baseline != chunk->fY) {
 
 1336         baseline = chunk->fY;
 
 1338      if (chunk->fNumDisplayChars <= 0) {
 
 1339         if (chunk->fStart[0] == 
'\t') {
 
 1344         for (j = 0; j < chunk->fNumDisplayChars; j++) {
 
 1346            if ((
c == 
'(') || (
c == 
')') || (
c == 
'\\') || (
c < 0x20) || (
c >= 
UChar_t(0x7f))) {
 
 1355               sprintf(buf + used, 
"\\%03o", 
c);
 
 1396                                const char *start, 
Int_t numChars,
 
 1399   LayoutChunk_t *chunk;
 
 1402   maxChunks = *maxPtr;
 
 1404      if (maxChunks == 0) {
 
 1409      chunk = 
new LayoutChunk_t[maxChunks];
 
 1416      *maxPtr = maxChunks;
 
 1420   chunk->fStart = start;
 
 1421   chunk->fNumChars = numChars;
 
 1422   chunk->fNumDisplayChars = numChars;
 
 1425   chunk->fTotalWidth = newX - curX;
 
 1426   chunk->fDisplayWidth = newX - curX;
 
 1449                          const char *source, 
Int_t numChars,
 
 1457   for (i = 0; i < numChars; i++) {
 
 1479                       const char *source, 
Int_t numChars,
 
 1484   if ((
x + (max_width * numChars) > 0x7fff)) {
 
 1492      numChars = 
MeasureChars(source, numChars, 0x7fff - 
x, 0, &length);
 
 1495   gVirtualX->DrawString(dst, gc, 
x, 
y, source, numChars);
 
 1545   if (!font || !*font) {
 
 1546      Error(
"GetFont", 
"argument may not be 0 or empty");
 
 1595   f->MeasureChars(
"0", 1, 0, 0, &
f->fTabWidth);
 
 1597   if (!
f->fTabWidth) {
 
 1598      f->fTabWidth = 
f->fFM.fMaxWidth;
 
 1605   if (!
f->fTabWidth) {
 
 1612   Int_t descent = 
f->fFM.fDescent;
 
 1613   f->fUnderlinePos = descent/2;  
 
 1614   f->fUnderlineHeight = 
f->fFA.fPointsize/10;
 
 1616   if (!
f->fUnderlineHeight) {
 
 1617      f->fUnderlineHeight = 1;
 
 1619   if (
f->fUnderlinePos + 
f->fUnderlineHeight > descent) {
 
 1625      f->fUnderlineHeight = descent - 
f->fUnderlinePos;
 
 1627      if (!
f->fUnderlineHeight) {
 
 1629         f->fUnderlineHeight = 1;
 
 1707      if (
f->RemoveReference() == 0) {
 
 1713            TNamedFont *nf = (TNamedFont *) font->
fNamedHash;
 
 1715            if ((nf->RemoveReference() == 0) && (nf->fDeletePending != 0)) {
 
 1734   while ((
f = (
TGFont*) next())) {
 
 1735      if (
f->fFontStruct == font) {
 
 1751   while ((
f = (
TGFont*) next())) {
 
 1752      if (
f->fFontH == font) {
 
 1780   return (
const char *)obj->
GetName();
 
 1793   const char *str = 0;
 
 1829         int len = strlen(str)+1;
 
 1830         result[i] = 
new char[len];
 
 1831         strlcpy(result[i], str, len);
 
 1833         result[i] = 
new char[20];
 
 1834         snprintf(result[i], 20, 
"%d", num);
 
 1878      out << 
"   TGFont *ufont;         // will reflect user font changes" << std::endl;
 
 1880   out << 
"   ufont = gClient->GetFont(" << quote << 
GetName() << quote << 
");" << std::endl;
 
 1899   while (*p && ((*p == 
' ') || (*p == 
'\t'))) {   
 
 1914      while (*p && (*p != 
'"')) {
 
 1923      while (*p && (*p != 
' ') && (*p != 
'\t')) {
 
 1952   XLFDAttributes_t xa;
 
 1954   int len = strlen(
string)+1;
 
 1955   char *str = 
new char[len];
 
 1956   strlcpy(str, 
string, len);
 
 1958   if (*str == 
'-' || *str == 
'*') {
 
 1987      if ((errno == ERANGE) || (end == 
s)) {
 
 2046   memset(field, 
'\0', 
sizeof (field));
 
 2049   if (*str == 
'-') str++;
 
 2052   src = (
char*)ds.
Data();
 
 2055   for (i = 0; *src != 
'\0'; src++) {
 
 2057         *src = tolower(
UChar_t(*src));
 
 2079            field[j + 1] = field[j];
 
 2134         xa->fFA.fPointsize /= 10;
 
 2161   xa->fFA.fPointsize = -xa->fFA.fPointsize;
 
 2191   const FontStateMap_t *
m;
 
 2193   if (!map->fStrKey) {
 
 2197   for (
m = map; 
m->fStrKey != 0; 
m++) {
 
 2198      if (strcasecmp(strKey, 
m->fStrKey) == 0) {
 
 2214   for ( ; map->fStrKey != 0; map++) {
 
 2215      if (numKey == map->fNumKey) 
return map->fStrKey;
 
 2240   return (ch != 
'*' && ch != 
'?');
 
 2261   char *family, *end, *p;
 
 2271   nameList = 
gVirtualX->ListFonts(
"*", 10000, numNames);
 
 2273   for (i = 0; i < numNames; i++) {
 
 2274      if (nameList[i][0] != 
'-') {
 
 2277      family = strchr(nameList[i] + 1, 
'-');
 
 2282      end = strchr(family, 
'-');
 
 2287      for (p = family; *p != 
'\0'; p++) {
 
 2298   dst = 
new char*[entries+1];
 
 2300   TIter next(&familyTable);
 
 2304   while ((obj = next())) {
 
 2323   for (i = 0; 
f[i] != 0; ++i) {
 
 2342   Int_t numNames, score, i, scaleable, pixelsize, xaPixelsize;
 
 2343   Int_t bestIdx, bestScore, bestScaleableIdx, bestScaleableScore;
 
 2344   XLFDAttributes_t xa;
 
 2349   const char *fmt, *family;
 
 2357   if (pixelsize < 0) {
 
 2359      d = -pixelsize * 25.4/72;
 
 2366      pixelsize = (int) 
d;
 
 2373   fmt = 
"-*-%.240s-*-*-*-*-*-*-*-*-*-*-*-*";
 
 2375   nameList = 
gVirtualX->ListFonts(buf.
Data(), 32768, numNames);
 
 2382      nameList = 
gVirtualX->ListFonts(buf.
Data(), 32768, numNames);
 
 2387         fontStruct = 
gVirtualX->LoadQueryFont(
"fixed");
 
 2390            fontStruct = 
gVirtualX->LoadQueryFont(
"*");
 
 2404   bestScaleableIdx = 0;
 
 2407   for (i = 0; i < numNames; i++) {
 
 2413      xaPixelsize = -xa.fFA.fPointsize;
 
 2420      if (xa.fFoundry && (strcasecmp(xa.fFoundry, 
"adobe") != 0)) {
 
 2423      if (!xa.fFA.fPointsize) {
 
 2434         if (xaPixelsize > pixelsize) {
 
 2435            score += (xaPixelsize - pixelsize) * 120;
 
 2437            score += (pixelsize - xaPixelsize) * 100;
 
 2464      if ((xa.fCharset == 
kFontCSNormal) && (xa.fEncoding != 1)) {
 
 2472         if (score < bestScaleableScore) {
 
 2473            bestScaleableIdx = i;
 
 2474            bestScaleableScore = score;
 
 2477         if (score < bestScore) {
 
 2495   if (bestScaleableScore < bestScore) {
 
 2501      str = nameList[bestScaleableIdx];
 
 2503         str = strchr(str + 1, 
'-');
 
 2507         rest = strchr(rest + 1, 
'-');
 
 2510      buf = 
TString::Format(
"%.240s-*-%d-*-*-*-*-*%s", nameList[bestScaleableIdx], pixelsize, rest);
 
 2516      buf = nameList[bestIdx];
 
 2524         if (bestScaleableScore < 
kMaxInt) {
 
 2535   font = 
MakeFont(fontPtr, fontStruct, buf);
 
 2554   fixedDefault = fixedDefault && ((*
name == 
'-') || (*
name == 
'*'));
 
 2577                             const char *fontName)
 
 2581   Int_t i, 
width, firstChar, lastChar, 
n, replaceOK;
 
 2584   XLFDAttributes_t xa;
 
 2590      newFont = 
new TGFont(fontName);
 
 2596      newFont->
fFA = xa.fFA;
 
 2612   gVirtualX->GetFontProperties(fontStruct, ascent, descent);
 
 2627   for (i = 0; i < 256; i++) {
 
 2628      if ((i == 160) || (i == 173) || (i == 177) ||
 
 2629          (i < firstChar) || (i > lastChar)) {
 
 2641   char ch[2] = {0, 0};
 
 2643   for (i = 0; i < 256; i++) {
 
 2672   for (i = 0; i < 256; i++) {
 
static const double x2[5]
static const double x1[5]
static RooMathCoreReg dummy
include TDocParser_001 C image html pict1_TDocParser_001 png width
R__EXTERN Int_t gErrorIgnoreLevel
static const FontStateMap_t gWeightMap[]
static char * GetToken(char *str)
static const FontStateMap_t gXlfdCharsetMap[]
static const FontStateMap_t gUnderlineMap[]
static const FontStateMap_t gOverstrikeMap[]
static int GetControlCharSubst(int c, char buf[4])
When displaying text in a widget, a backslashed escape sequence is substituted for control characters...
static const FontStateMap_t gXlfdSlantMap[]
static const FontStateMap_t gSlantMap[]
static const FontStateMap_t gXlfdgWeightMap[]
static const FontStateMap_t gXlfdSetwidthMap[]
char * StrDup(const char *str)
Duplicate the string str.
virtual Int_t GetEntries() const
virtual void SetOwner(Bool_t enable=kTRUE)
Set whether this collection is the owner (enable==true) of its content.
FontStruct_t GetFontByName(const char *name, Bool_t fixedDefault=kTRUE) const
Get a font by name.
Bool_t ParseFontName(const char *string, FontAttributes_t *fa)
Converts a string into a set of font attributes that can be used to construct a font.
TGFont * GetFont(const char *font, Bool_t fixedDefault=kTRUE)
Get the specified font.
const char * NameOfFont(TGFont *font)
Given a font, return a textual string identifying it.
char ** GetFontFamilies()
Return information about the font families that are available on the current display.
Bool_t ParseXLFD(const char *string, XLFDAttributes_t *xa)
Break up a fully specified XLFD into a set of font attributes.
int FindStateNum(const FontStateMap_t *map, const char *strKey)
Given a lookup table, map a string to a number in the table.
TGFont * GetNativeFont(const char *name, Bool_t fixedDefault=kTRUE)
The return value is a pointer to an TGFont object that represents the native font.
TGFontPool(const TGFontPool &fp)
const char * GetUid(const char *string)
Given a string, this procedure returns a unique identifier for the string.
Bool_t FieldSpecified(const char *field)
Helper function for ParseXLFD().
TGFont * FindFontByHandle(FontH_t font) const
Find font based on its font handle. Returns 0 if font is not found.
virtual ~TGFontPool()
Cleanup font pool.
void FreeFont(const TGFont *font)
Free font. If ref count is 0 delete font.
char ** GetAttributeInfo(const FontAttributes_t *fa)
Return information about the font attributes as an array of strings.
const char * FindStateString(const FontStateMap_t *map, int numKey)
Given a lookup table, map a number to a string in the table.
void FreeFontFamilies(char **f)
Delete an array of families allocated GetFontFamilies() method.
TGFont * GetFontFromAttributes(FontAttributes_t *fa, TGFont *fontPtr)
Given a desired set of attributes for a font, find a font with the closest matching attributes and cr...
TGFont * MakeFont(TGFont *font, FontStruct_t fontStruct, const char *fontName)
Helper for GetNativeFont() and GetFontFromAttributes().
TGFont * FindFont(FontStruct_t font) const
Find font based on its font struct. Returns 0 if font is not found.
void FreeAttributeInfo(char **info)
Free attributes info.
void Print(Option_t *option="") const
List all fonts in the pool.
void GetFontMetrics(FontMetrics_t *m) const
Get font metrics.
void UnderlineChars(Drawable_t dst, GContext_t gc, const char *string, Int_t x, Int_t y, Int_t firstChar, Int_t lastChar) const
This procedure draws an underline for a given range of characters in a given string.
friend class TGTextLayout
void DrawCharsExp(Drawable_t dst, GContext_t gc, const char *source, Int_t numChars, Int_t x, Int_t y) const
Draw a string of characters on the screen.
Int_t MeasureChars(const char *source, Int_t numChars, Int_t maxLength, Int_t flags, Int_t *length) const
Determine the number of characters from the string that will fit in the given horizontal span.
Int_t TextWidth(const char *string, Int_t numChars=-1) const
A wrapper function for the more complicated interface of MeasureChars.
FontStruct_t operator()() const
Not inline due to a bug in g++ 2.96 20000731 (Red Hat Linux 7.0)
LayoutChunk_t * NewChunk(TGTextLayout *layout, int *maxPtr, const char *start, int numChars, int curX, int newX, int y) const
Helper function for ComputeTextLayout().
virtual void SavePrimitive(std::ostream &out, Option_t *="")
Save the used font as a C++ statement(s) on output stream out.
Int_t XTextWidth(const char *string, Int_t numChars=-1) const
Return text widht in pixels.
TGTextLayout * ComputeTextLayout(const char *string, Int_t numChars, Int_t wrapLength, Int_t justify, Int_t flags, UInt_t *width, UInt_t *height) const
Computes the amount of screen space needed to display a multi-line, justified string of text.
void Print(Option_t *option="") const
Print font info.
Int_t PostscriptFontName(TString *dst) const
Return the name of the corresponding Postscript font for this TGFont.
virtual ~TGFont()
Delete font.
void DrawChars(Drawable_t dst, GContext_t gc, const char *source, Int_t numChars, Int_t x, Int_t y) const
Perform a quick sanity check to ensure we won't overflow the X coordinate space.
void DrawText(Drawable_t dst, GContext_t gc, Int_t x, Int_t y, Int_t firstChar, Int_t lastChar) const
Use the information in the TGTextLayout object to display a multi-line, justified string of text.
Int_t PointToChar(Int_t x, Int_t y) const
Use the information in the TGTextLayout token to determine the character closest to the given point.
Int_t IntersectText(Int_t x, Int_t y, Int_t w, Int_t h) const
Determines whether a text layout lies entirely inside, entirely outside, or overlaps a given rectangl...
void ToPostscript(TString *dst) const
Outputs the contents of a text layout in Postscript format.
Int_t DistanceToText(Int_t x, Int_t y) const
Computes the distance in pixels from the given point to the given text layout.
Int_t CharBbox(Int_t index, Int_t *x, Int_t *y, Int_t *w, Int_t *h) const
Use the information in the TGTextLayout token to return the bounding box for the character specified ...
virtual ~TGTextLayout()
destructor
void UnderlineChar(Drawable_t dst, GContext_t gc, Int_t x, Int_t y, Int_t underline) const
Use the information in the TGTextLayout object to display an underline below an individual character.
THashTable implements a hash table to store TObject's.
TObject * Remove(TObject *obj)
Remove object from the hashtable.
void Add(TObject *obj)
Add object to the hash table.
void Print(Option_t *option, Int_t recurse) const
Print the collection header and its elements.
TObject * FindObject(const char *name) const
Find object using its name.
virtual const char * GetName() const
Returns name of object.
Collectable string class.
const char * GetName() const
Returns name of object.
Mother of all ROOT objects.
virtual const char * GetName() const
Returns name of object.
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
Definitions for TRefCnt, base class for reference counted objects.
UInt_t References() const
const char * Data() const
TString & Append(const char *cs)
static TString Format(const char *fmt,...)
Static method which formats a string using a printf style format descriptor and return a TString.
double dist(Rotation3D const &r1, Rotation3D const &r2)
static constexpr double s
Double_t Hypot(Double_t x, Double_t y)
#define dest(otri, vertexptr)