www.pudn.com > ucosv2(GUI).rar > GUIPolyE.c


/*
*********************************************************************************************************
*                                                uC/GUI
*                        Universal graphic software for embedded applications
*
*                       (c) Copyright 2002, Micrium Inc., Weston, FL
*                       (c) Copyright 2002, SEGGER Microcontroller Systeme GmbH
*
*              µC/GUI is protected by international copyright laws. Knowledge of the
*              source code may not be used to write a similar product. This file may
*              only be used in accordance with a license and should not be redistributed
*              in any way. We appreciate your understanding and fairness.
*
---------------------------------------------------------------------- 
File        : GUIPolyE.c 
Purpose     : Polygon enlarge 
---------------------------------------------------------------------- 
*/ 
 
#include  
#include "GUI.H" 
#include "GUIDebug.H" 
 
 
typedef struct { 
  float x,y; 
} tfPoint; 
 
static int fround ( float f) { 
  if (f>0) 
    return f+0.5; 
  return f-0.5; 
} 
 
 
 
static void Normalize(tfPoint* pfPoint) { 
  float fx = pfPoint->x; 
  float fy = pfPoint->y; 
  float r = sqrt(fx*fx + fy*fy); 
  if (r > 0) { 
    pfPoint->x = fx/r; 
    pfPoint->y = fy/r; 
  } 
} 
 
static void ReverseLen(tfPoint* pfPoint) { 
  float fx = pfPoint->x; 
  float fy = pfPoint->y; 
  float r = sqrt(fx*fx/2 + fy*fy/2); 
  if (r > 0) { 
    pfPoint->x = fx/r/r; 
    pfPoint->y = fy/r/r; 
  } 
} 
 
static void GetVect(tfPoint* pfPoint, const GUI_POINT* pSrc, int NumPoints, int Index) { 
  int Off0 = (Index + NumPoints-1) % NumPoints; 
  int Off1 = Index % NumPoints; 
  pfPoint->x = pSrc[Off1].x - pSrc[Off0].x;  
  pfPoint->y = pSrc[Off1].y - pSrc[Off0].y;  
} 
 
/******************************************************************* 
* 
*                  GUI_EnlargePolygon 
* 
******************************************************************** 
*/ 
 
#if 0 
void GUI_EnlargePolygon(GUI_POINT* pDest, const GUI_POINT* pSrc, int NumPoints, int Len) { 
  int j; 
  /* Calc destination points */ 
  for (j=0; jx = (pSrc+j)->x + x; 
    (pDest+j)->y = (pSrc+j)->y + y; 
  } 
} 
 
#else 
 
void GUI_EnlargePolygon(GUI_POINT* pDest, const GUI_POINT* pSrc, int NumPoints, int Len) { 
  int j; 
  /* Calc destination points */ 
  for (j=0; jx = (pSrc+j)->x + x; 
    (pDest+j)->y = (pSrc+j)->y + y; 
  } 
} 
#endif