xref: /petsc/src/sys/classes/draw/interface/dtext.c (revision 2c71b3e237ead271e4f3aa1505f92bf476e3413d)
15c6c1daeSBarry Smith /*
25c6c1daeSBarry Smith        Provides the calling sequences for all the basic PetscDraw routines.
35c6c1daeSBarry Smith */
4af0996ceSBarry Smith #include <petsc/private/drawimpl.h>  /*I "petscdraw.h" I*/
55c6c1daeSBarry Smith 
68f69470aSLisandro Dalcin /*@C
78f69470aSLisandro Dalcin    PetscDrawString - PetscDraws text onto a drawable.
88f69470aSLisandro Dalcin 
98f69470aSLisandro Dalcin    Not Collective
108f69470aSLisandro Dalcin 
118f69470aSLisandro Dalcin    Input Parameters:
128f69470aSLisandro Dalcin +  draw - the drawing context
139400ad77SLisandro Dalcin .  xl,yl - the coordinates of lower left corner of text
148f69470aSLisandro Dalcin .  cl - the color of the text
158f69470aSLisandro Dalcin -  text - the text to draw
168f69470aSLisandro Dalcin 
178f69470aSLisandro Dalcin    Level: beginner
188f69470aSLisandro Dalcin 
1950d92d24SPierre Jolivet .seealso: PetscDrawStringVertical(), PetscDrawStringCentered(), PetscDrawStringBoxed(), PetscDrawStringSetSize(),
20ba1e01c4SBarry Smith           PetscDrawStringGetSize(), PetscDrawLine(), PetscDrawRectangle(), PetscDrawTriangle(), PetscDrawEllipse(),
21ba1e01c4SBarry Smith           PetscDrawMarker(), PetscDrawPoint()
228f69470aSLisandro Dalcin 
238f69470aSLisandro Dalcin @*/
248f69470aSLisandro Dalcin PetscErrorCode  PetscDrawString(PetscDraw draw,PetscReal xl,PetscReal yl,int cl,const char text[])
258f69470aSLisandro Dalcin {
268f69470aSLisandro Dalcin   PetscErrorCode ierr;
278f69470aSLisandro Dalcin 
288f69470aSLisandro Dalcin   PetscFunctionBegin;
298f69470aSLisandro Dalcin   PetscValidHeaderSpecific(draw,PETSC_DRAW_CLASSID,1);
308f69470aSLisandro Dalcin   PetscValidCharPointer(text,5);
31*2c71b3e2SJacob Faibussowitsch   PetscCheckFalse(!draw->ops->string,PETSC_COMM_SELF,PETSC_ERR_SUP,"This draw type %s does not support drawing strings",((PetscObject)draw)->type_name);
328f69470aSLisandro Dalcin   ierr = (*draw->ops->string)(draw,xl,yl,cl,text);CHKERRQ(ierr);
338f69470aSLisandro Dalcin   PetscFunctionReturn(0);
348f69470aSLisandro Dalcin }
358f69470aSLisandro Dalcin 
368f69470aSLisandro Dalcin /*@C
378f69470aSLisandro Dalcin    PetscDrawStringVertical - PetscDraws text onto a drawable.
388f69470aSLisandro Dalcin 
398f69470aSLisandro Dalcin    Not Collective
408f69470aSLisandro Dalcin 
418f69470aSLisandro Dalcin    Input Parameters:
428f69470aSLisandro Dalcin +  draw - the drawing context
438f69470aSLisandro Dalcin .  xl,yl - the coordinates of upper left corner of text
448f69470aSLisandro Dalcin .  cl - the color of the text
458f69470aSLisandro Dalcin -  text - the text to draw
468f69470aSLisandro Dalcin 
478f69470aSLisandro Dalcin    Level: beginner
488f69470aSLisandro Dalcin 
4950d92d24SPierre Jolivet .seealso: PetscDrawString(), PetscDrawStringCentered(), PetscDrawStringBoxed(), PetscDrawStringSetSize(),
50ba1e01c4SBarry Smith           PetscDrawStringGetSize()
518f69470aSLisandro Dalcin 
528f69470aSLisandro Dalcin @*/
538f69470aSLisandro Dalcin PetscErrorCode  PetscDrawStringVertical(PetscDraw draw,PetscReal xl,PetscReal yl,int cl,const char text[])
548f69470aSLisandro Dalcin {
559400ad77SLisandro Dalcin   int            i;
569400ad77SLisandro Dalcin   char           chr[2] = {0, 0};
579400ad77SLisandro Dalcin   PetscReal      tw,th;
588f69470aSLisandro Dalcin   PetscErrorCode ierr;
598f69470aSLisandro Dalcin 
608f69470aSLisandro Dalcin   PetscFunctionBegin;
618f69470aSLisandro Dalcin   PetscValidHeaderSpecific(draw,PETSC_DRAW_CLASSID,1);
628f69470aSLisandro Dalcin   PetscValidCharPointer(text,5);
639400ad77SLisandro Dalcin 
649400ad77SLisandro Dalcin   if (draw->ops->stringvertical) {
658f69470aSLisandro Dalcin     ierr = (*draw->ops->stringvertical)(draw,xl,yl,cl,text);CHKERRQ(ierr);
668f69470aSLisandro Dalcin     PetscFunctionReturn(0);
678f69470aSLisandro Dalcin   }
689400ad77SLisandro Dalcin   ierr = PetscDrawStringGetSize(draw,&tw,&th);CHKERRQ(ierr);
699400ad77SLisandro Dalcin   for (i = 0; (chr[0] = text[i]); i++) {
709400ad77SLisandro Dalcin     ierr = PetscDrawString(draw,xl,yl-th*(i+1),cl,chr);CHKERRQ(ierr);
719400ad77SLisandro Dalcin   }
729400ad77SLisandro Dalcin   PetscFunctionReturn(0);
739400ad77SLisandro Dalcin }
748f69470aSLisandro Dalcin 
7551fa3d41SBarry Smith /*@C
7651fa3d41SBarry Smith    PetscDrawStringCentered - PetscDraws text onto a drawable centered at a point
7751fa3d41SBarry Smith 
7851fa3d41SBarry Smith    Not Collective
7951fa3d41SBarry Smith 
8051fa3d41SBarry Smith    Input Parameters:
8151fa3d41SBarry Smith +  draw - the drawing context
8251fa3d41SBarry Smith .  xc - the coordinates of right-left center of text
8351fa3d41SBarry Smith .  yl - the coordinates of lower edge of text
8451fa3d41SBarry Smith .  cl - the color of the text
8551fa3d41SBarry Smith -  text - the text to draw
8651fa3d41SBarry Smith 
8751fa3d41SBarry Smith    Level: beginner
8851fa3d41SBarry Smith 
8950d92d24SPierre Jolivet .seealso: PetscDrawStringVertical(), PetscDrawString(), PetscDrawStringBoxed(), PetscDrawStringSetSize(),
90ba1e01c4SBarry Smith           PetscDrawStringGetSize()
9151fa3d41SBarry Smith 
9251fa3d41SBarry Smith @*/
9351fa3d41SBarry Smith PetscErrorCode  PetscDrawStringCentered(PetscDraw draw,PetscReal xc,PetscReal yl,int cl,const char text[])
9451fa3d41SBarry Smith {
9551fa3d41SBarry Smith   PetscErrorCode ierr;
9651fa3d41SBarry Smith   size_t         len;
9751fa3d41SBarry Smith   PetscReal      tw,th;
9851fa3d41SBarry Smith 
9951fa3d41SBarry Smith   PetscFunctionBegin;
10051fa3d41SBarry Smith   PetscValidHeaderSpecific(draw,PETSC_DRAW_CLASSID,1);
10151fa3d41SBarry Smith   PetscValidCharPointer(text,5);
10251fa3d41SBarry Smith 
10351fa3d41SBarry Smith   ierr = PetscDrawStringGetSize(draw,&tw,&th);CHKERRQ(ierr);
10451fa3d41SBarry Smith   ierr = PetscStrlen(text,&len);CHKERRQ(ierr);
1059400ad77SLisandro Dalcin   xc   = xc - len*tw/2;
10651fa3d41SBarry Smith   ierr = PetscDrawString(draw,xc,yl,cl,text);CHKERRQ(ierr);
10751fa3d41SBarry Smith   PetscFunctionReturn(0);
10851fa3d41SBarry Smith }
10951fa3d41SBarry Smith 
1105c6c1daeSBarry Smith /*@C
11151fa3d41SBarry Smith    PetscDrawStringBoxed - Draws a string with a box around it
1125c6c1daeSBarry Smith 
1135c6c1daeSBarry Smith    Not Collective
1145c6c1daeSBarry Smith 
1155c6c1daeSBarry Smith    Input Parameters:
1165c6c1daeSBarry Smith +  draw - the drawing context
1175c6c1daeSBarry Smith .  sxl - the coordinates of center of the box
1185c6c1daeSBarry Smith .  syl - the coordinates of top line of box
1195c6c1daeSBarry Smith .  sc - the color of the text
1205c6c1daeSBarry Smith .  bc - the color of the bounding box
1215c6c1daeSBarry Smith -  text - the text to draw
1225c6c1daeSBarry Smith 
1235c6c1daeSBarry Smith    Output Parameter:
1245c6c1daeSBarry Smith .   w,h - width and height of resulting box (optional)
1255c6c1daeSBarry Smith 
1265c6c1daeSBarry Smith    Level: beginner
1275c6c1daeSBarry Smith 
12850d92d24SPierre Jolivet .seealso: PetscDrawStringVertical(), PetscDrawString(), PetscDrawStringCentered(), PetscDrawStringSetSize(),
129ba1e01c4SBarry Smith           PetscDrawStringGetSize()
1305c6c1daeSBarry Smith 
1315c6c1daeSBarry Smith @*/
13251fa3d41SBarry Smith PetscErrorCode  PetscDrawStringBoxed(PetscDraw draw,PetscReal sxl,PetscReal syl,int sc,int bc,const char text[],PetscReal *w,PetscReal *h)
1335c6c1daeSBarry Smith {
1345c6c1daeSBarry Smith   PetscErrorCode ierr;
1355c6c1daeSBarry Smith   PetscReal      top,left,right,bottom,tw,th;
1365c6c1daeSBarry Smith   size_t         len,mlen = 0;
1375c6c1daeSBarry Smith   char           **array;
1385c6c1daeSBarry Smith   int            cnt,i;
1395c6c1daeSBarry Smith 
1405c6c1daeSBarry Smith   PetscFunctionBegin;
1415c6c1daeSBarry Smith   PetscValidHeaderSpecific(draw,PETSC_DRAW_CLASSID,1);
142064a246eSJacob Faibussowitsch   PetscValidCharPointer(text,6);
1435c6c1daeSBarry Smith 
14442963b84SBarry Smith   if (draw->ops->boxedstring) {
14542963b84SBarry Smith     ierr = (*draw->ops->boxedstring)(draw,sxl,syl,sc,bc,text,w,h);CHKERRQ(ierr);
14642963b84SBarry Smith     PetscFunctionReturn(0);
14742963b84SBarry Smith   }
14842963b84SBarry Smith 
1495c6c1daeSBarry Smith   ierr = PetscStrToArray(text,'\n',&cnt,&array);CHKERRQ(ierr);
1505c6c1daeSBarry Smith   for (i=0; i<cnt; i++) {
1515c6c1daeSBarry Smith     ierr = PetscStrlen(array[i],&len);CHKERRQ(ierr);
1525c6c1daeSBarry Smith     mlen = PetscMax(mlen,len);
1535c6c1daeSBarry Smith   }
1545c6c1daeSBarry Smith 
1555c6c1daeSBarry Smith   ierr = PetscDrawStringGetSize(draw,&tw,&th);CHKERRQ(ierr);
1565c6c1daeSBarry Smith 
1575c6c1daeSBarry Smith   top    = syl;
1585c6c1daeSBarry Smith   left   = sxl - .5*(mlen + 2)*tw;
1595c6c1daeSBarry Smith   right  = sxl + .5*(mlen + 2)*tw;
1605c6c1daeSBarry Smith   bottom = syl - (1.0 + cnt)*th;
1615c6c1daeSBarry Smith   if (w) *w = right - left;
1625c6c1daeSBarry Smith   if (h) *h = top - bottom;
1635c6c1daeSBarry Smith 
1645c6c1daeSBarry Smith   /* compute new bounding box */
1655c6c1daeSBarry Smith   draw->boundbox_xl = PetscMin(draw->boundbox_xl,left);
1665c6c1daeSBarry Smith   draw->boundbox_xr = PetscMax(draw->boundbox_xr,right);
1675c6c1daeSBarry Smith   draw->boundbox_yl = PetscMin(draw->boundbox_yl,bottom);
1685c6c1daeSBarry Smith   draw->boundbox_yr = PetscMax(draw->boundbox_yr,top);
1695c6c1daeSBarry Smith 
1705c6c1daeSBarry Smith   /* top, left, bottom, right lines */
1715c6c1daeSBarry Smith   ierr = PetscDrawLine(draw,left,top,right,top,bc);CHKERRQ(ierr);
1725c6c1daeSBarry Smith   ierr = PetscDrawLine(draw,left,bottom,left,top,bc);CHKERRQ(ierr);
1735c6c1daeSBarry Smith   ierr = PetscDrawLine(draw,right,bottom,right,top,bc);CHKERRQ(ierr);
1745c6c1daeSBarry Smith   ierr = PetscDrawLine(draw,left,bottom,right,bottom,bc);CHKERRQ(ierr);
1755c6c1daeSBarry Smith 
1765c6c1daeSBarry Smith   for  (i=0; i<cnt; i++) {
1775c6c1daeSBarry Smith     ierr = PetscDrawString(draw,left + tw,top - (1.5 + i)*th,sc,array[i]);CHKERRQ(ierr);
1785c6c1daeSBarry Smith   }
1795c6c1daeSBarry Smith   ierr = PetscStrToArrayDestroy(cnt,array);CHKERRQ(ierr);
1805c6c1daeSBarry Smith   PetscFunctionReturn(0);
1815c6c1daeSBarry Smith }
1828f69470aSLisandro Dalcin 
1838f69470aSLisandro Dalcin /*@
1848f69470aSLisandro Dalcin    PetscDrawStringSetSize - Sets the size for character text.
1858f69470aSLisandro Dalcin 
1868f69470aSLisandro Dalcin    Not Collective
1878f69470aSLisandro Dalcin 
1888f69470aSLisandro Dalcin    Input Parameters:
1898f69470aSLisandro Dalcin +  draw - the drawing context
1908f69470aSLisandro Dalcin .  width - the width in user coordinates
1918f69470aSLisandro Dalcin -  height - the character height in user coordinates
1928f69470aSLisandro Dalcin 
1938f69470aSLisandro Dalcin    Level: advanced
1948f69470aSLisandro Dalcin 
1958f69470aSLisandro Dalcin    Note:
1968f69470aSLisandro Dalcin    Only a limited range of sizes are available.
1978f69470aSLisandro Dalcin 
19850d92d24SPierre Jolivet .seealso: PetscDrawStringVertical(), PetscDrawString(), PetscDrawStringCentered(), PetscDrawStringBoxed(),
199ba1e01c4SBarry Smith           PetscDrawStringGetSize()
2008f69470aSLisandro Dalcin 
2018f69470aSLisandro Dalcin @*/
2028f69470aSLisandro Dalcin PetscErrorCode  PetscDrawStringSetSize(PetscDraw draw,PetscReal width,PetscReal height)
2038f69470aSLisandro Dalcin {
2048f69470aSLisandro Dalcin   PetscErrorCode ierr;
2058f69470aSLisandro Dalcin 
2068f69470aSLisandro Dalcin   PetscFunctionBegin;
2078f69470aSLisandro Dalcin   PetscValidHeaderSpecific(draw,PETSC_DRAW_CLASSID,1);
2088f69470aSLisandro Dalcin   if (draw->ops->stringsetsize) {
2098f69470aSLisandro Dalcin     ierr = (*draw->ops->stringsetsize)(draw,width,height);CHKERRQ(ierr);
2108f69470aSLisandro Dalcin   }
2118f69470aSLisandro Dalcin   PetscFunctionReturn(0);
2128f69470aSLisandro Dalcin }
2138f69470aSLisandro Dalcin 
2148f69470aSLisandro Dalcin /*@
2158f69470aSLisandro Dalcin    PetscDrawStringGetSize - Gets the size for character text.  The width is
2168f69470aSLisandro Dalcin    relative to the user coordinates of the window.
2178f69470aSLisandro Dalcin 
2188f69470aSLisandro Dalcin    Not Collective
2198f69470aSLisandro Dalcin 
2208f69470aSLisandro Dalcin    Input Parameters:
2218f69470aSLisandro Dalcin +  draw - the drawing context
2228f69470aSLisandro Dalcin .  width - the width in user coordinates
2238f69470aSLisandro Dalcin -  height - the character height
2248f69470aSLisandro Dalcin 
2258f69470aSLisandro Dalcin    Level: advanced
2268f69470aSLisandro Dalcin 
22750d92d24SPierre Jolivet .seealso: PetscDrawStringVertical(), PetscDrawString(), PetscDrawStringCentered(), PetscDrawStringBoxed(),
228ba1e01c4SBarry Smith           PetscDrawStringSetSize()
2298f69470aSLisandro Dalcin 
2308f69470aSLisandro Dalcin @*/
2318f69470aSLisandro Dalcin PetscErrorCode  PetscDrawStringGetSize(PetscDraw draw,PetscReal *width,PetscReal *height)
2328f69470aSLisandro Dalcin {
2338f69470aSLisandro Dalcin   PetscErrorCode ierr;
2348f69470aSLisandro Dalcin 
2358f69470aSLisandro Dalcin   PetscFunctionBegin;
2368f69470aSLisandro Dalcin   PetscValidHeaderSpecific(draw,PETSC_DRAW_CLASSID,1);
237*2c71b3e2SJacob Faibussowitsch   PetscCheckFalse(!draw->ops->stringgetsize,PETSC_COMM_SELF,PETSC_ERR_SUP,"This draw type %s does not support getting string size",((PetscObject)draw)->type_name);
2388f69470aSLisandro Dalcin   ierr = (*draw->ops->stringgetsize)(draw,width,height);CHKERRQ(ierr);
2398f69470aSLisandro Dalcin   PetscFunctionReturn(0);
2408f69470aSLisandro Dalcin }
2418f69470aSLisandro Dalcin 
242