[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[freetype2] anuj-distance-field 901441a 14/95: [sdf] Added basic outline
From: |
Anuj Verma |
Subject: |
[freetype2] anuj-distance-field 901441a 14/95: [sdf] Added basic outline of the functions required to generate sdf. |
Date: |
Sun, 2 Aug 2020 01:10:26 -0400 (EDT) |
branch: anuj-distance-field
commit 901441a6cb82e85dc196b98fe196f2b192ba92a2
Author: Anuj Verma <anujv@iitbhilai.ac.in>
Commit: Anuj Verma <anujv@iitbhilai.ac.in>
[sdf] Added basic outline of the functions required to generate sdf.
---
[GSoC]ChangeLog | 21 ++++++
src/sdf/ftsdf.c | 215 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 236 insertions(+)
diff --git a/[GSoC]ChangeLog b/[GSoC]ChangeLog
index 75bbc11..62ee95a 100644
--- a/[GSoC]ChangeLog
+++ b/[GSoC]ChangeLog
@@ -1,3 +1,24 @@
+2020-06-27 Anuj Verma <anujv@iitbhilai.ac.in>
+
+ [sdf] Added basic outline of the functions required to
+ generate sdf.
+
+ * src/sdf/ftsdf.c (SDF_Signed_Distance): Added struct which
+ represent a complete signed distance and can be used to
+ get cross, dot, sign etc.
+
+ * src/sdf/ftsdf.c (SDF_Iterator_IO): This struct will be used
+ while `FT_List_Iterate'.
+
+ * src/sdf/ftsdf.c (sdf_generate): Added function which genearte
+ SDF from `SDF_Shape'.
+
+ * src/sdf/ftsdf.c (sdf_edge_iterator_func,
+ sdf_contour_iterator_func): Added funcions
+ which iterate through contours and edges and return the shortest
+ distance.
+
+
2020-06-26 Anuj Verma <anujv@iitbhilai.ac.in>
[sdf] Added `SDF_Raster_Params' struct which extends
diff --git a/src/sdf/ftsdf.c b/src/sdf/ftsdf.c
index 340bc49..2a722b0 100644
--- a/src/sdf/ftsdf.c
+++ b/src/sdf/ftsdf.c
@@ -8,6 +8,14 @@
/**************************************************************************
*
+ * macros
+ *
+ */
+
+ #define FT_INT_26D6( x ) ( x * 64 ) /* convert int to 26.6 fixed point */
+
+ /**************************************************************************
+ *
* typedefs
*
*/
@@ -15,6 +23,8 @@
typedef FT_Vector FT_26D6_Vec; /* with 26.6 fixed point components */
typedef FT_Vector FT_16D16_Vec; /* with 16.16 fixed point components */
+ typedef FT_Fixed FT_16D16; /* 16.16 fixed point representation */
+
/**************************************************************************
*
* structures and enums
@@ -67,6 +77,40 @@
} SDF_Shape;
+ typedef struct SDF_Signed_Distance_
+ {
+ /* Nearest point the outline to a given point. */
+ /* [note]: This is not a *direction* vector, this */
+ /* simply a *point* vector on the grid. */
+ FT_16D16_Vec neartest_point;
+
+ /* The normalized direction of the curve at the */
+ /* above point. */
+ /* [note]: This is a *direction* vector. */
+ FT_16D16_Vec direction;
+
+ /* Unsigned shortest distance from the point to */
+ /* the above `nearest_point'. */
+ FT_16D16 distance;
+
+ /* Represent weather the `nearest_point' is outside */
+ /* or inside the contour corresponding to the edge. */
+ /* [note]: This sign may or may not be correct, */
+ /* therefore it must be checked properly in */
+ /* case there is an ambiguity. */
+ FT_Char sign;
+
+ } SDF_Signed_Distance;
+
+ /* This struct servers as both input and output while */
+ /* iterating through the contours and edges. */
+ typedef struct SDF_Iterator_IO_
+ {
+ FT_26D6_Vec current_point; /* input */
+ SDF_Signed_Distance shortest_point; /* output */
+
+ } SDF_Iterator_IO;
+
/**************************************************************************
*
* constants, initializer and destructor
@@ -87,6 +131,10 @@
static
const SDF_Shape null_shape = { NULL, { NULL, NULL } };
+ static
+ const SDF_Signed_Distance max_sdf_dist = { { 0, 0 }, { 0, 0 },
+ FT_INT_MAX, 0 };
+
/* Creates a new `SDF_Edge' on the heap and assigns the `edge' */
/* pointer to the newly allocated memory. */
static FT_Error
@@ -547,6 +595,173 @@
#endif
+ /*************************************************************************/
+ /*************************************************************************/
+ /** **/
+ /** RASTERIZER **/
+ /** **/
+ /*************************************************************************/
+ /*************************************************************************/
+
+ /**************************************************************************
+ *
+ * @Function:
+ * sdf_edge_iterator_func
+ *
+ * @Description:
+ * This function find the shortest distance from a point to
+ * a given point. The function assign the output if current edge
+ * distance is smaller than the output. Make sure to assign max
+ * distance to io.shortest_point before calling the iterator first
+ * time.
+ *
+ * @Input:
+ * [TODO]
+ *
+ * @Return:
+ * [TODO]
+ */
+ static FT_Error
+ sdf_edge_iterator_func( FT_ListNode node,
+ void* user )
+ {
+ FT_Error error = FT_Err_Ok;
+ SDF_Iterator_IO* io = (SDF_Iterator_IO*)user;
+
+
+ if ( !node || !user )
+ {
+ error = FT_THROW( Invalid_Argument );
+ goto Exit;
+ }
+
+ Exit:
+ return error;
+ }
+
+ /**************************************************************************
+ *
+ * @Function:
+ * sdf_contour_iterator_func
+ *
+ * @Description:
+ * This function iterate through all the edges that make up
+ * the contour and find the shortest distance from a point to
+ * this contour. The function assign the output if any edge distance
+ * is smaller than the output. Make sure to assign max distance to
+ * io.shortest_point before calling the iterator for the first time.
+ *
+ * @Input:
+ * [TODO]
+ *
+ * @Return:
+ * [TODO]
+ */
+ static FT_Error
+ sdf_contour_iterator_func( FT_ListNode node,
+ void* user )
+ {
+ FT_Error error = FT_Err_Ok;
+ SDF_Iterator_IO* io = (SDF_Iterator_IO*)user;
+
+ if ( !node || !user )
+ {
+ error = FT_THROW( Invalid_Argument );
+ goto Exit;
+ }
+
+ Exit:
+ return error;
+ }
+
+ /**************************************************************************
+ *
+ * @Function:
+ * sdf_generate
+ *
+ * @Description:
+ * This is the main function that is responsible for generating
+ * signed distance fields. The function will not align or compute
+ * the size of the `bitmap', therefore setup the `bitmap' properly
+ * and transform the `shape' appropriately before calling this
+ * function.
+ * Currently we check all the pixels against all the contours and
+ * all the edges.
+ *
+ * @Input:
+ * [TODO]
+ *
+ * @Return:
+ * [TODO]
+ */
+ static FT_Error
+ sdf_generate( const SDF_Shape* shape,
+ FT_UInt spread,
+ FT_Bitmap* bitmap )
+ {
+ FT_Error error = FT_Err_Ok;
+ FT_UInt width = 0;
+ FT_UInt rows = 0;
+ FT_UInt x = 0; /* used to loop in x direction i.e. width */
+ FT_UInt y = 0; /* used to loop in y direction i.e. rows */
+
+ if ( !shape || !bitmap )
+ {
+ error = FT_THROW( Invalid_Argument );
+ goto Exit;
+ }
+
+ if ( spread < MIN_SPREAD || spread > MAX_SPREAD )
+ {
+ error = FT_THROW( Invalid_Argument );
+ goto Exit;
+ }
+
+ width = bitmap->width;
+ rows = bitmap->rows;
+
+ if ( width == 0 || rows == 0 )
+ {
+ FT_TRACE0(( "[sdf] sdf_generate:\n"
+ " Cannot render glyph with width/height == 0\n"
+ " (width, height provided [%d, %d])", width, rows ));
+ error = FT_THROW( Cannot_Render_Glyph );
+ goto Exit;
+ }
+
+ /* loop through all the rows */
+ for ( y = 0; y < rows; y++ )
+ {
+ /* loop through all the pixels of a row */
+ for ( x = 0; x < width; x++ )
+ {
+ /* `grid_point' is the current pixel position */
+ /* our task is to find the shortest distance */
+ /* from this point to the entire shape. */
+ FT_26D6_Vec grid_point = { FT_INT_26D6( x ),
+ FT_INT_26D6( y ) };
+ SDF_Iterator_IO arg;
+
+
+ /* This `grid_point' is at the corner, but we */
+ /* use the center of the pixel. */
+ grid_point.x += FT_INT_26D6( 1 ) / 2;
+ grid_point.y += FT_INT_26D6( 1 ) / 2;
+
+ arg.current_point = grid_point;
+ arg.shortest_point = max_sdf_dist;
+
+ /* [TODO]: iterate through all the contours */
+
+ /* [TODO]: Now check the returned distance and assign */
+ /* the values to the bitmap. */
+ }
+ }
+
+ Exit:
+ return FT_THROW( Unimplemented_Feature );
+ }
+
/**************************************************************************
*
* interface functions
[Prev in Thread] |
Current Thread |
[Next in Thread] |
- [freetype2] anuj-distance-field 901441a 14/95: [sdf] Added basic outline of the functions required to generate sdf.,
Anuj Verma <=