| /* | 
 |  * Copyright 2012 Google Inc. | 
 |  * | 
 |  * Use of this source code is governed by a BSD-style license that can be | 
 |  * found in the LICENSE file. | 
 |  */ | 
 |  | 
 | #ifndef picture_utils_DEFINED | 
 | #define picture_utils_DEFINED | 
 |  | 
 | #include "SkBitmap.h" | 
 |  | 
 | class SkData; | 
 | class SkString; | 
 |  | 
 | namespace sk_tools { | 
 |     // since PNG insists on unpremultiplying our alpha, we take no precision | 
 |     // chances and force all pixels to be 100% opaque, otherwise on compare we | 
 |     // may not get a perfect match. | 
 |     // | 
 |     // This expects a bitmap with a config type of 8888 and for the pixels to | 
 |     // not be on the GPU. | 
 |     void force_all_opaque(const SkBitmap& bitmap); | 
 |  | 
 |     /** | 
 |      * Replaces all instances of oldChar with newChar in str. | 
 |      */ | 
 |     void replace_char(SkString* str, const char oldChar, const char newChar); | 
 |  | 
 |     // Returns true if the string ends with % | 
 |     bool is_percentage(const char* const string); | 
 |  | 
 |     // Prepares the bitmap so that it can be written. | 
 |     // | 
 |     // Specifically, it configures the bitmap, allocates pixels and then | 
 |     // erases the pixels to transparent black. | 
 |     void setup_bitmap(SkBitmap* bitmap, int width, int height); | 
 |  | 
 |     /** | 
 |      * Write a bitmap file to disk. | 
 |      * | 
 |      * @param bm the bitmap to record | 
 |      * @param dirPath directory within which to write the image file | 
 |      * @param subdirOrNull subdirectory within dirPath, or nullptr to just write into dirPath | 
 |      * @param baseName last part of the filename | 
 |      * | 
 |      * @return true if written out successfully | 
 |      */ | 
 |     bool write_bitmap_to_disk(const SkBitmap& bm, const SkString& dirPath, | 
 |                               const char *subdirOrNull, const SkString& baseName); | 
 |  | 
 |     // Return raw unpremultiplied RGBA bytes, suitable for storing in a PNG. The output | 
 |     // colors are assumed to be sRGB values. This is only guaranteed to work for the | 
 |     // cases that are currently emitted by tools: | 
 |     // Linear premul 8888, sRGB premul 8888, Linear premul F16 | 
 |     sk_sp<SkData> encode_bitmap_for_png(SkBitmap bitmap); | 
 |  | 
 | } // namespace sk_tools | 
 |  | 
 | #endif  // picture_utils_DEFINED |