[sdf] Started the `bsdf' rasterier.
* src/sdf/ftbsdf.c (*): Fix line endings. * src/sdf/ftbsdf.c (bsdf_copy_source_to_target): Added function to copy the source bitmap to the center of the target bitmap and also convert it to normalized 16 bits per pixel bitmap.
This commit is contained in:
parent
1d51c5ef7b
commit
2c77a8acb2
|
@ -1,3 +1,14 @@
|
|||
2020-07-24 Anuj Verma <anujv@iitbhilai.ac.in>
|
||||
|
||||
[sdf] Started the `bsdf' rasterier.
|
||||
|
||||
* src/sdf/ftbsdf.c (*): Fix line endings.
|
||||
|
||||
* src/sdf/ftbsdf.c (bsdf_copy_source_to_target): Added
|
||||
function to copy the source bitmap to the center of
|
||||
the target bitmap and also convert it to normalized
|
||||
16 bits per pixel bitmap.
|
||||
|
||||
2020-07-19 Anuj Verma <anujv@iitbhilai.ac.in>
|
||||
|
||||
[sdf] Added interface functions for `bsdf' converter.
|
||||
|
|
172
src/sdf/ftbsdf.c
172
src/sdf/ftbsdf.c
|
@ -5,6 +5,123 @@
|
|||
#include "ftsdf.h"
|
||||
#include "ftsdferrs.h"
|
||||
|
||||
/**************************************************************************
|
||||
*
|
||||
* useful macros
|
||||
*
|
||||
*/
|
||||
|
||||
/* Convenient macro which calls the function */
|
||||
/* and returns if any error occurs. */
|
||||
#define FT_CALL( x ) do \
|
||||
{ \
|
||||
error = ( x ); \
|
||||
if ( error != FT_Err_Ok ) \
|
||||
goto Exit; \
|
||||
} while ( 0 )
|
||||
|
||||
/**************************************************************************
|
||||
*
|
||||
* rasterizer functions
|
||||
*
|
||||
*/
|
||||
|
||||
static FT_Error
|
||||
bsdf_copy_source_to_target( const FT_Bitmap* source,
|
||||
FT_Bitmap* target )
|
||||
{
|
||||
FT_Error error = FT_Err_Ok;
|
||||
FT_Bool is_monochrome = 0;
|
||||
|
||||
FT_Int x_diff, y_diff;
|
||||
FT_Int num_channels;
|
||||
FT_Byte* t, s;
|
||||
|
||||
/* again check the parameters (probably unnecessary) */
|
||||
if ( !source || !target )
|
||||
{
|
||||
error = FT_THROW( Invalid_Argument );
|
||||
goto Exit;
|
||||
}
|
||||
|
||||
/* Because of the way we convert bitmap to SDF */
|
||||
/* i.e. aligning the source to the center of the */
|
||||
/* target, the target's width/rows must be checked */
|
||||
/* before copying. */
|
||||
if ( target->width < source->width ||
|
||||
target->rows < source->rows )
|
||||
{
|
||||
error = FT_THROW( Invalid_Argument );
|
||||
goto Exit;
|
||||
}
|
||||
|
||||
/* check pixel mode */
|
||||
if ( source->pixel_mode == FT_PIXEL_MODE_NONE )
|
||||
{
|
||||
FT_ERROR(( "[bsdf] bsdf_copy_source_to_target: "
|
||||
"Invalid pixel mode of source bitmap" ));
|
||||
error = FT_THROW( Invalid_Argument );
|
||||
goto Exit;
|
||||
}
|
||||
|
||||
/* make sure target bitmap is 16bpp */
|
||||
if ( target->pixel_mode != FT_PIXEL_MODE_GRAY16 )
|
||||
{
|
||||
FT_ERROR(( "[bsdf] bsdf_copy_source_to_target: "
|
||||
"Invalid pixel mode of target bitmap" ));
|
||||
error = FT_THROW( Invalid_Argument );
|
||||
goto Exit;
|
||||
}
|
||||
|
||||
#ifdef FT_DEBUG_LEVEL_TRACE
|
||||
if ( source->pixel_mode == FT_PIXEL_MODE_MONO )
|
||||
{
|
||||
FT_TRACE0(( "[bsdf] bsdf_copy_source_to_target:\n"
|
||||
"The `bsdf' renderer can convert monochrome bitmap\n"
|
||||
"to SDF, but the results are not perfect because there\n"
|
||||
"is no way to approximate actual outline from monochrome\n"
|
||||
"bitmap. Consider using anti-aliased bitmap instead.\n" ));
|
||||
}
|
||||
#endif
|
||||
|
||||
/* Calculate the difference in width and rows */
|
||||
/* of the target and source. */
|
||||
x_diff = target->width - source->width;
|
||||
y_diff = target->rows - source->rows;
|
||||
|
||||
x_diff /= 2;
|
||||
y_diff /= 2;
|
||||
|
||||
t = target->buffer;
|
||||
s = source->buffer;
|
||||
|
||||
/* For now we only support pixel mode `FT_PIXEL_MODE_MONO' */
|
||||
/* and `FT_PIXEL_MODE_GRAY'. More will be added later. */
|
||||
/* [NOTE]: We can also use `FT_Bitmap_Convert' to convert */
|
||||
/* bitmap to 8bpp. To avoid extra allocation and */
|
||||
/* since the target bitmap can be 16bpp we manually */
|
||||
/* convert the source bitmap to desired bpp. */
|
||||
switch ( source->pixel_mode ) {
|
||||
case FT_PIXEL_MODE_MONO:
|
||||
/* [TODO] */
|
||||
error = FT_THROW( Unimplemented_Feature );
|
||||
break;
|
||||
case FT_PIXEL_MODE_GRAY:
|
||||
/* [TODO] */
|
||||
error = FT_THROW( Unimplemented_Feature );
|
||||
break;
|
||||
default:
|
||||
FT_ERROR(( "[bsdf] bsdf_copy_source_to_target: "
|
||||
"unsopported pixel mode of source bitmap\n" ));
|
||||
error = FT_THROW( Unimplemented_Feature );
|
||||
break;
|
||||
}
|
||||
|
||||
Exit:
|
||||
return error;
|
||||
}
|
||||
|
||||
|
||||
/**************************************************************************
|
||||
*
|
||||
* interface functions
|
||||
|
@ -49,10 +166,59 @@
|
|||
bsdf_raster_render( FT_Raster raster,
|
||||
const FT_Raster_Params* params )
|
||||
{
|
||||
FT_UNUSED( raster );
|
||||
FT_UNUSED( params );
|
||||
FT_Error error = FT_Err_Ok;
|
||||
FT_Bitmap* source = NULL;
|
||||
FT_Bitmap* target = NULL;
|
||||
|
||||
return FT_THROW( Unimplemented_Feature ) ;
|
||||
const SDF_Raster_Params* sdf_params = (const SDF_Raster_Params*)params;
|
||||
|
||||
|
||||
FT_UNUSED( raster );
|
||||
|
||||
/* check for valid parameters */
|
||||
if ( !params )
|
||||
{
|
||||
error = FT_THROW( Invalid_Argument );
|
||||
goto Exit;
|
||||
}
|
||||
|
||||
/* check if the flag is set */
|
||||
if ( sdf_params->root.flags != FT_RASTER_FLAG_SDF )
|
||||
{
|
||||
error = FT_THROW( Raster_Corrupted );
|
||||
goto Exit;
|
||||
}
|
||||
|
||||
source = sdf_params->root.source;
|
||||
target = sdf_params->root.target;
|
||||
|
||||
/* check the source and target bitmap */
|
||||
if ( !source || !target )
|
||||
{
|
||||
error = FT_THROW( Invalid_Argument );
|
||||
goto Exit;
|
||||
}
|
||||
|
||||
/* check if spread is set properly */
|
||||
if ( sdf_params->spread > MAX_SPREAD ||
|
||||
sdf_params->spread < MIN_SPREAD )
|
||||
{
|
||||
FT_TRACE0((
|
||||
"[bsdf] bsdf_raster_render:\n"
|
||||
" The `spread' field of `SDF_Raster_Params' is invalid,\n"
|
||||
" the value of this field must be within [%d, %d].\n"
|
||||
" Also, you must pass `SDF_Raster_Params' instead of the\n"
|
||||
" default `FT_Raster_Params' while calling this function\n"
|
||||
" and set the fields properly.\n"
|
||||
, MIN_SPREAD, MAX_SPREAD) );
|
||||
error = FT_THROW( Invalid_Argument );
|
||||
goto Exit;
|
||||
}
|
||||
|
||||
FT_CALL( bsdf_copy_source_to_target( source, target ) );
|
||||
|
||||
Exit:
|
||||
return error;
|
||||
}
|
||||
|
||||
static void
|
||||
|
|
Loading…
Reference in New Issue