2014-03-11 15:57:40 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2014 Google Inc.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
|
|
|
#ifndef SkDistanceFieldGen_DEFINED
|
|
|
|
#define SkDistanceFieldGen_DEFINED
|
|
|
|
|
2014-04-14 22:05:07 +00:00
|
|
|
#include "SkTypes.h"
|
|
|
|
|
|
|
|
// the max magnitude for the distance field
|
2016-02-24 16:33:10 +00:00
|
|
|
// distance values are limited to the range (-SK_DistanceFieldMagnitude, SK_DistanceFieldMagnitude]
|
2014-04-14 22:05:07 +00:00
|
|
|
#define SK_DistanceFieldMagnitude 4
|
|
|
|
// we need to pad around the original glyph to allow our maximum distance of
|
|
|
|
// SK_DistanceFieldMagnitude texels away from any edge
|
2014-04-15 17:53:21 +00:00
|
|
|
#define SK_DistanceFieldPad 4
|
|
|
|
// the rect we render with is inset from the distance field glyph size to allow for bilerp
|
|
|
|
#define SK_DistanceFieldInset 2
|
2014-04-14 22:05:07 +00:00
|
|
|
|
2016-02-24 16:33:10 +00:00
|
|
|
// For the fragment shader:
|
|
|
|
// The distance field is constructed as unsigned char values,
|
|
|
|
// so that the zero value is at 128, and the supported range of distances is [-4 * 127/128, 4].
|
|
|
|
// Hence our multiplier (width of the range) is 4 * 255/128 and zero threshold is 128/255.
|
2014-04-14 22:05:07 +00:00
|
|
|
#define SK_DistanceFieldMultiplier "7.96875"
|
|
|
|
#define SK_DistanceFieldThreshold "0.50196078431"
|
|
|
|
|
2014-03-11 15:57:40 +00:00
|
|
|
/** Given 8-bit mask data, generate the associated distance field
|
|
|
|
|
|
|
|
* @param distanceField The distance field to be generated. Should already be allocated
|
2014-04-14 22:05:07 +00:00
|
|
|
* by the client with the padding above.
|
2014-03-11 15:57:40 +00:00
|
|
|
* @param image 8-bit mask we're using to generate the distance field.
|
2014-04-14 22:05:07 +00:00
|
|
|
* @param w Width of the original image.
|
|
|
|
* @param h Height of the original image.
|
|
|
|
* @param rowBytes Size of each row in the image, in bytes
|
|
|
|
*/
|
|
|
|
bool SkGenerateDistanceFieldFromA8Image(unsigned char* distanceField,
|
|
|
|
const unsigned char* image,
|
2014-12-12 16:51:38 +00:00
|
|
|
int w, int h, size_t rowBytes);
|
2014-04-14 22:05:07 +00:00
|
|
|
|
|
|
|
/** Given 1-bit mask data, generate the associated distance field
|
|
|
|
|
|
|
|
* @param distanceField The distance field to be generated. Should already be allocated
|
|
|
|
* by the client with the padding above.
|
|
|
|
* @param image 1-bit mask we're using to generate the distance field.
|
|
|
|
* @param w Width of the original image.
|
|
|
|
* @param h Height of the original image.
|
|
|
|
* @param rowBytes Size of each row in the image, in bytes
|
|
|
|
*/
|
|
|
|
bool SkGenerateDistanceFieldFromBWImage(unsigned char* distanceField,
|
|
|
|
const unsigned char* image,
|
2014-12-12 16:51:38 +00:00
|
|
|
int w, int h, size_t rowBytes);
|
2014-04-14 22:05:07 +00:00
|
|
|
|
|
|
|
/** Given width and height of original image, return size (in bytes) of distance field
|
|
|
|
* @param w Width of the original image.
|
|
|
|
* @param h Height of the original image.
|
2014-03-11 15:57:40 +00:00
|
|
|
*/
|
2014-04-14 22:05:07 +00:00
|
|
|
inline size_t SkComputeDistanceFieldSize(int w, int h) {
|
|
|
|
return (w + 2*SK_DistanceFieldPad) * (h + 2*SK_DistanceFieldPad) * sizeof(unsigned char);
|
|
|
|
}
|
2014-03-11 15:57:40 +00:00
|
|
|
|
|
|
|
#endif
|