2017-11-23 20:42:14 +01:00
|
|
|
/**
|
2017-11-23 21:28:36 +01:00
|
|
|
* @file lv_circ.c
|
2017-11-23 20:42:14 +01:00
|
|
|
* Circle drawing algorithm (with Bresenham)
|
|
|
|
* Only a 1/8 circle is calculated. Use CIRC_OCT1_X, CIRC_OCT1_Y macros to get
|
|
|
|
* the other octets.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*********************
|
|
|
|
* INCLUDES
|
|
|
|
*********************/
|
2019-01-01 01:34:29 +01:00
|
|
|
#include "lv_circ.h"
|
2017-11-23 20:42:14 +01:00
|
|
|
|
|
|
|
/*********************
|
|
|
|
* DEFINES
|
|
|
|
*********************/
|
|
|
|
|
|
|
|
/**********************
|
|
|
|
* TYPEDEFS
|
|
|
|
**********************/
|
|
|
|
|
|
|
|
/**********************
|
|
|
|
* STATIC PROTOTYPES
|
|
|
|
**********************/
|
|
|
|
|
|
|
|
/**********************
|
|
|
|
* STATIC VARIABLES
|
|
|
|
**********************/
|
|
|
|
|
|
|
|
/**********************
|
|
|
|
* MACROS
|
|
|
|
**********************/
|
|
|
|
|
|
|
|
/**********************
|
|
|
|
* GLOBAL FUNCTIONS
|
|
|
|
**********************/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initialize the circle drawing
|
|
|
|
* @param c pointer to a point. The coordinates will be calculated here
|
|
|
|
* @param tmp point to a variable. It will store temporary data
|
|
|
|
* @param radius radius of the circle
|
|
|
|
*/
|
2017-11-23 21:28:36 +01:00
|
|
|
void lv_circ_init(lv_point_t * c, lv_coord_t * tmp, lv_coord_t radius)
|
2017-11-23 20:42:14 +01:00
|
|
|
{
|
|
|
|
c->x = radius;
|
|
|
|
c->y = 0;
|
|
|
|
*tmp = 1 - radius;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test the circle drawing is ready or not
|
|
|
|
* @param c same as in circ_init
|
|
|
|
* @return true if the circle is not ready yet
|
|
|
|
*/
|
2017-11-23 21:28:36 +01:00
|
|
|
bool lv_circ_cont(lv_point_t * c)
|
2017-11-23 20:42:14 +01:00
|
|
|
{
|
|
|
|
return c->y <= c->x ? true : false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the next point from the circle
|
|
|
|
* @param c same as in circ_init. The next point stored here.
|
|
|
|
* @param tmp same as in circ_init.
|
|
|
|
*/
|
2017-11-23 21:28:36 +01:00
|
|
|
void lv_circ_next(lv_point_t * c, lv_coord_t * tmp)
|
2017-11-23 20:42:14 +01:00
|
|
|
{
|
|
|
|
c->y++;
|
2018-06-19 09:49:58 +02:00
|
|
|
|
|
|
|
if(*tmp <= 0) {
|
|
|
|
(*tmp) += 2 * c->y + 1; // Change in decision criterion for y -> y+1
|
2017-11-23 20:42:14 +01:00
|
|
|
} else {
|
2018-06-19 09:49:58 +02:00
|
|
|
c->x--;
|
|
|
|
(*tmp) += 2 * (c->y - c->x) + 1; // Change for y -> y+1, x -> x-1
|
|
|
|
}
|
2017-11-23 20:42:14 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**********************
|
|
|
|
* STATIC FUNCTIONS
|
|
|
|
**********************/
|