home *** CD-ROM | disk | FTP | other *** search
/ Fresh Fish 4 / FreshFish_May-June1994.bin / new / misc / math / cp / source / verttext.c < prev   
C/C++ Source or Header  |  1994-05-01  |  6KB  |  192 lines

  1. #include <exec/types.h>
  2. #include <exec/memory.h>
  3. #include <graphics/rastport.h>
  4. #include <proto/exec.h>
  5. #include <proto/graphics.h>
  6.  
  7.  
  8. struct RastPort *AllocRastPort(UWORD, UWORD, UWORD);
  9. struct RastPort *FreeRastPort(struct RastPort *);
  10. void Rotate(struct RastPort *, struct RastPort *);
  11.  
  12. /* Function to write Text vertically. Function allocates
  13.    two temporary rastports with bitmaps sized to fit the
  14.    text string using the source rastport's font. Next, it
  15.    calls Text() to write the string into tempRP then rotates
  16.    the text 90 degrees into vertRP. Finally,it uses ClipBlit
  17.    to place the text back into the source rastport at the
  18.    current position. Works with colorfonts and proportional
  19.    fonts. No guarantee it is bug free, or if it will work at
  20.    all ("it works here").
  21.  
  22.    Its arguments are the RastPort, the string, and the stringlength.
  23. */
  24.  
  25. void VertText(struct RastPort *r, UBYTE *s, LONG l)
  26. {
  27. struct TextExtent txex;
  28. struct RastPort  *tempRP;
  29. struct RastPort  *vertRP;
  30. UWORD   d, w, h;
  31.  
  32.      TextExtent( r, s, l, &txex);
  33.      
  34.      w = txex.te_Width + 8;  /* add 1 byte to be sure it fits */
  35.      h = txex.te_Height;
  36.      d = r->BitMap->Depth;
  37.      
  38.      tempRP = AllocRastPort( d, w, h);
  39.      vertRP = AllocRastPort( d, h, w);
  40.  
  41.      if ( tempRP && vertRP )
  42.        {
  43.           SetRast( tempRP, 0);
  44.           SetRast( vertRP, 0);
  45.  
  46.           SetFont( tempRP, r->Font);
  47.           SetAPen( tempRP, r->FgPen);
  48.  
  49.           Move( tempRP, 0, tempRP->Font->tf_Baseline);
  50.           Text( tempRP, s, l);
  51.  
  52.           Rotate( tempRP, vertRP);
  53.      
  54.           ClipBlit(vertRP, 0, 0, r, r->cp_x - r->Font->tf_Baseline, r->cp_y - w, h, w, 0xCC);
  55.           
  56.        }
  57.      if (vertRP) FreeRastPort( vertRP );
  58.      if (tempRP) FreeRastPort( tempRP );
  59. }
  60. /* Allocates and initializes a rastport. Must be freed
  61.    by call to FreeRastPort.
  62. */
  63. struct RastPort *AllocRastPort( UWORD depth, UWORD width, UWORD height)
  64. {
  65.    WORD i;
  66.  
  67.    struct BitMap   *b;
  68.    struct RastPort *r;
  69.  
  70.    b = (struct BitMap *) AllocMem(sizeof(struct BitMap), MEMF_CLEAR|MEMF_CHIP);
  71.    if (b == NULL) return(NULL);
  72.  
  73.    r = (struct RastPort *) AllocMem(sizeof(struct RastPort), MEMF_CLEAR);
  74.    if (r == NULL) goto cleanup;
  75.  
  76.    if (width & 0x7) width = (width & 0xFFF8) + 8;
  77.  
  78.    InitBitMap(b, depth, width, height);
  79.  
  80.    for (i = 0; i < depth; i++)
  81.      {
  82.           b->Planes[i] = (PLANEPTR) AllocRaster( width, height);
  83.           if (b->Planes[i] == NULL) goto cleanup;
  84.      }
  85.  
  86.    InitRastPort(r);
  87.    r->BitMap = b;
  88.  
  89.    return(r);
  90.  
  91. cleanup:
  92.    if (b) {
  93.       width = b->BytesPerRow << 3;
  94.       height = b->Rows;
  95.  
  96.       for (i = 0; i < depth; i++)
  97.          if (b->Planes[i]) FreeRaster(b->Planes[i], width, height);
  98.  
  99.       FreeMem(b, sizeof(struct BitMap));
  100.    }
  101.    if (r) FreeMem(r, sizeof(struct RastPort));
  102.  
  103.    return(NULL);
  104. }
  105.  
  106. /*
  107.    This function frees a RastPort allocated by AllocRastPort()
  108. */
  109. struct RastPort *FreeRastPort(struct RastPort *r)
  110. {
  111.    struct BitMap *b;
  112.    UWORD  width, height;
  113.    WORD   i;
  114.  
  115.    if (r == NULL) return(NULL);
  116.  
  117.    if (b = r->BitMap)
  118.      {
  119.           width = b->BytesPerRow << 3;
  120.           height = b->Rows;
  121.           for (i = 0; i < (int) b->Depth; i++)
  122.                if (b->Planes[i]) FreeRaster(b->Planes[i], width, height);
  123.           FreeMem(b, sizeof(struct BitMap));
  124.      }
  125.    FreeMem(r, sizeof(struct RastPort));
  126.  
  127.    return(NULL);
  128. }
  129. /* Rotates bitmap in source rastport (srp) 90 degrees and places result
  130.    in destination bitmap (drp). Both bitmaps should be allocated by call
  131.    to AllocRastPort(). Destination bitmap should be allocated with the
  132.    width and height reversed. This function does not check for this and
  133.    the results will be very unpredicatable if this is not the case.
  134.    This function splits up source bitmap into blocks of 8*8 bits and
  135.    rotates each block then writes them to the correct block in the
  136.    destination bitmap. 
  137. */
  138. void Rotate(struct RastPort *srp, struct RastPort *drp)
  139. {
  140.    static UWORD cbits[8] = {0x80, 0x40, 0x20, 0x10, 0x08, 0x04, 0x02, 0x01};
  141.  
  142.    UBYTE  *sptr, *dptr, *ptr;
  143.    UBYTE  nbits[8]; 
  144.    UWORD  bits;
  145.    WORD   i, j, k, l, m, n;
  146.    UWORD  drxbp, dblkc;
  147.  
  148.    /* offset to start of lower left block of destination bitmap */
  149.    drxbp = (drp->BitMap->Rows - 8) * drp->BitMap->BytesPerRow;
  150.  
  151.    /* destination block decrement */
  152.    dblkc =  drp->BitMap->BytesPerRow << 3;
  153.  
  154.    for (i = 0; i < srp->BitMap->Depth; i++)
  155.      {
  156.           sptr = (UBYTE *) srp->BitMap->Planes[i];
  157.           dptr = (UBYTE *) drp->BitMap->Planes[i];
  158.           
  159.           for (j = 0; j < drp->BitMap->BytesPerRow; j++)
  160.             {
  161.                n = srp->BitMap->BytesPerRow * j<<3;
  162.  
  163.                for (k = drxbp + j; k >= j; k -= dblkc)
  164.                  {
  165.                    for (l = 0; l < 8; l++) nbits[l] = 0;
  166.  
  167.                     ptr = &sptr[n];
  168.                     for (l = 0; l < 8; l++)
  169.                       {
  170.                          bits = ptr[0];
  171.                          for (m = 0; m < 8; m++)
  172.                            {
  173.                               if (bits & cbits[m]) nbits[7 - m] |= cbits[l];
  174.                            }
  175.                          ptr += srp->BitMap->BytesPerRow;
  176.                       }
  177.  
  178.                     ptr = &dptr[k];  
  179.                     for (l = 0; l < 8; l++)
  180.                       {
  181.                          ptr[0] = nbits[l];
  182.                          ptr   += drp->BitMap->BytesPerRow;
  183.                       }
  184.  
  185.                     n++; /* increment source block key */
  186.                  }  
  187.             }
  188.      }
  189.  
  190.    return;
  191. }
  192.