Home| base |src.lib|graphic|ps| PostScriptEllipse Index

PostScriptEllipse

Syntax
int PostScriptEllipse(struct PostScript *ptr, struct PostScriptMatrix *matrix, float x,float y,float w,float h, int fill,unsigned int color, float width, struct PostScriptDash *dash,struct PostScriptClip *clip);
Header
base/rps.h
Library
rps
Description

The PostScriptEllipse function plots an ellipse.

The argument ptr is a pointer to the PostScript control structure. The argument matrix is an optional transformation matrix that can be applied to the ellipse. If this is set to a NULL pointer then no transformation is applied. The position of the center of the ellipse is given by the arguments x, and y. The horizontal and vertical radii are given by the arguments w and h.

If the argument fill is set to a non-zero value then the ellipse will be plotted as a solid shape, not an outline.

The color used to plot the rectangle is given by the color which is a 24-bit number that represents the red,green and blue components of the color as 8-bit number. The red channel occupies the most significant bits and the blue channel occupies the least significant bits.

The width of the line used to plot the ellipse is controlled using the argument width, a value of zero will plot a hairline. The dot-dash pattern used to plot the ellipse is given by dash. If this is set to a NULL pointer, a solid line is plotted.

The clipping polygon is given by the argument clip. If this is set to a NULL pointer, no clipping is performed.

Returns
Returns zero on success. On error, (-1) is returned.
Errors
On error, (-1) is returned.
Example
PostScriptEllipse
Source Code: PostScriptEllipse.c

/* PostScriptEllipse
   =================
   Author: R.J.Barnes
 Copyright (c) 2012 The Johns Hopkins University/Applied Physics Laboratory

This file is part of the Radar Software Toolkit (RST).

RST is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.

Modifications:




#include <stdio.h>
#include <stdlib.h>
#include "rfbuffer.h"
#include "rps.h"

int stream(char *buf,int sze,void *data) {
  FILE *fp;
  fp=(FILE *) data;
  fwrite(buf,sze,1,stdout);
  return 0;
} 


int main(int argc,char *argv[]) {

  struct PostScript *ps=NULL;

  float wdt=400,hgt=400;
  float xoff=50,yoff=50;

  unsigned int fgcol=0xff000000;

  ps=PostScriptMake();
  PostScriptSetText(ps,stream,stdout);

  PostScriptMakeDocument(ps,xoff,yoff,wdt,hgt,0);
  PostScriptMakePlot(ps);
   


  PostScriptEllipse(ps,NULL,wdt/2,hgt/2,wdt/2-20,hgt/2-20,
                  1,fgcol,0,NULL,NULL);


  PostScriptEndPlot(ps);
  PostScriptEndDocument(ps);
  return 0;
}