1 /*
2  * Copyright 2017 Google Inc.
3  *
4  * Use of this source code is governed by a BSD-style license that can be
5  * found in the LICENSE file.
6  */
7 
8 #ifndef SkWebpEncoder_DEFINED
9 #define SkWebpEncoder_DEFINED
10 
11 #include "SkEncoder.h"
12 
13 class SkWStream;
14 
15 namespace SkWebpEncoder {
16 
17     enum class Compression {
18         kLossy,
19         kLossless,
20     };
21 
22     struct SK_API Options {
23         /**
24          *  |fCompression| determines whether we will use webp lossy or lossless compression.
25          *
26          *  |fQuality| must be in [0.0f, 100.0f].
27          *  If |fCompression| is kLossy, |fQuality| corresponds to the visual quality of the
28          *  encoding.  Decreasing the quality will result in a smaller encoded image.
29          *  If |fCompression| is kLossless, |fQuality| corresponds to the amount of effort
30          *  put into the encoding.  Lower values will compress faster into larger files,
31          *  while larger values will compress slower into smaller files.
32          *
33          *  This scheme is designed to match the libwebp API.
34          */
35         Compression fCompression = Compression::kLossy;
36         float fQuality = 100.0f;
37     };
38 
39     /**
40      *  Encode the |src| pixels to the |dst| stream.
41      *  |options| may be used to control the encoding behavior.
42      *
43      *  Returns true on success.  Returns false on an invalid or unsupported |src|.
44      */
45     SK_API bool Encode(SkWStream* dst, const SkPixmap& src, const Options& options);
46 }
47 
48 #endif
49