| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2014 Google Inc. | 2 * Copyright 2014 Google Inc. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
| 5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
| 6 */ | 6 */ |
| 7 | 7 |
| 8 #include "SkDistanceFieldGen.h" | 8 #include "SkDistanceFieldGen.h" |
| 9 #include "SkPoint.h" | 9 #include "SkPoint.h" |
| 10 | 10 |
| (...skipping 325 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 336 SkASSERT(copyPtr); | 336 SkASSERT(copyPtr); |
| 337 | 337 |
| 338 // we expand our temp data by one more on each side to simplify | 338 // we expand our temp data by one more on each side to simplify |
| 339 // the scanning code -- will always be treated as infinitely far away | 339 // the scanning code -- will always be treated as infinitely far away |
| 340 int pad = SK_DistanceFieldPad + 1; | 340 int pad = SK_DistanceFieldPad + 1; |
| 341 | 341 |
| 342 // set params for distance field data | 342 // set params for distance field data |
| 343 int dataWidth = width + 2*pad; | 343 int dataWidth = width + 2*pad; |
| 344 int dataHeight = height + 2*pad; | 344 int dataHeight = height + 2*pad; |
| 345 | 345 |
| 346 // create zeroed temp edge+DFData storage | 346 // create temp data |
| 347 SkAutoFree storage(sk_calloc_throw(dataWidth*dataHeight*(1 + sizeof(DFData))
)); | 347 size_t dataSize = dataWidth*dataHeight*sizeof(DFData); |
| 348 unsigned char* edgePtr = (unsigned char*)storage.get(); | 348 SkAutoSMalloc<1024> dfStorage(dataSize); |
| 349 DFData* dataPtr = (DFData*)(edgePtr + dataWidth*dataHeight); | 349 DFData* dataPtr = (DFData*) dfStorage.get(); |
| 350 sk_bzero(dataPtr, dataSize); |
| 351 |
| 352 SkAutoSMalloc<1024> edgeStorage(dataWidth*dataHeight*sizeof(char)); |
| 353 unsigned char* edgePtr = (unsigned char*) edgeStorage.get(); |
| 354 sk_bzero(edgePtr, dataWidth*dataHeight*sizeof(char)); |
| 350 | 355 |
| 351 // copy glyph into distance field storage | 356 // copy glyph into distance field storage |
| 352 init_glyph_data(dataPtr, edgePtr, copyPtr, | 357 init_glyph_data(dataPtr, edgePtr, copyPtr, |
| 353 dataWidth, dataHeight, | 358 dataWidth, dataHeight, |
| 354 width+2, height+2, SK_DistanceFieldPad); | 359 width+2, height+2, SK_DistanceFieldPad); |
| 355 | 360 |
| 356 // create initial distance data, particularly at edges | 361 // create initial distance data, particularly at edges |
| 357 init_distances(dataPtr, edgePtr, dataWidth, dataHeight); | 362 init_distances(dataPtr, edgePtr, dataWidth, dataHeight); |
| 358 | 363 |
| 359 // now perform Euclidean distance transform to propagate distances | 364 // now perform Euclidean distance transform to propagate distances |
| (...skipping 147 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 507 *currDestPtr++ = (mask & (1 << i)) ? 0xff : 0; | 512 *currDestPtr++ = (mask & (1 << i)) ? 0xff : 0; |
| 508 } | 513 } |
| 509 } | 514 } |
| 510 currSrcScanLine += rowBytes; | 515 currSrcScanLine += rowBytes; |
| 511 *currDestPtr++ = 0; | 516 *currDestPtr++ = 0; |
| 512 } | 517 } |
| 513 sk_bzero(currDestPtr, (width+2)*sizeof(char)); | 518 sk_bzero(currDestPtr, (width+2)*sizeof(char)); |
| 514 | 519 |
| 515 return generate_distance_field_from_image(distanceField, copyPtr, width, hei
ght); | 520 return generate_distance_field_from_image(distanceField, copyPtr, width, hei
ght); |
| 516 } | 521 } |
| OLD | NEW |