GUIPolyR.c
上传用户:zbk8730
上传日期:2017-08-10
资源大小:12168k
文件大小:1k
源码类别:

uCOS

开发平台:

C/C++

  1. /*
  2. *********************************************************************************************************
  3. *                                                uC/GUI
  4. *                        Universal graphic software for embedded applications
  5. *
  6. *                       (c) Copyright 2002, Micrium Inc., Weston, FL
  7. *                       (c) Copyright 2002, SEGGER Microcontroller Systeme GmbH
  8. *
  9. *              礐/GUI is protected by international copyright laws. Knowledge of the
  10. *              source code may not be used to write a similar product. This file may
  11. *              only be used in accordance with a license and should not be redistributed
  12. *              in any way. We appreciate your understanding and fairness.
  13. *
  14. ----------------------------------------------------------------------
  15. File        : GUIPolyR.c
  16. Purpose     : Polygon rotation
  17. ----------------------------------------------------------------------
  18. */
  19. #include <math.h>
  20. #include "GUI.H"
  21. /*******************************************************************
  22. *
  23. *                  GUI_RotatePolygon
  24. *
  25. ********************************************************************
  26. */
  27. void GUI_RotatePolygon(GUI_POINT* pDest, const GUI_POINT* pSrc, int NumPoints, float Angle) {
  28.   int j;
  29.   float fcos = cos(Angle);
  30.   float fsin = sin(Angle);
  31.   for (j=0; j<NumPoints; j++) {
  32.     int x = (pSrc+j)->x;
  33.     int y = (pSrc+j)->y;
  34.     (pDest+j)->x =  x * fcos + y * fsin;
  35.     (pDest+j)->y = -x * fsin + y * fcos;
  36.   }
  37. }