forked from chromium/chromium
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathskia_utils_base.cc
110 lines (91 loc) · 3.06 KB
/
skia_utils_base.cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
// Copyright (c) 2013 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "skia/ext/skia_utils_base.h"
#include <stdint.h>
#include "base/pickle.h"
#include "third_party/skia/include/core/SkBitmap.h"
#include "third_party/skia/include/core/SkData.h"
#include "third_party/skia/include/core/SkEncodedImageFormat.h"
#include "third_party/skia/include/core/SkImage.h"
#include "third_party/skia/include/core/SkSerialProcs.h"
namespace skia {
bool ReadSkString(base::PickleIterator* iter, SkString* str) {
int reply_length;
const char* reply_text;
if (!iter->ReadData(&reply_text, &reply_length))
return false;
if (str)
str->set(reply_text, reply_length);
return true;
}
bool ReadSkFontIdentity(base::PickleIterator* iter,
SkFontConfigInterface::FontIdentity* identity) {
uint32_t reply_id;
uint32_t reply_ttcIndex;
int reply_length;
const char* reply_text;
if (!iter->ReadUInt32(&reply_id) ||
!iter->ReadUInt32(&reply_ttcIndex) ||
!iter->ReadData(&reply_text, &reply_length))
return false;
if (identity) {
identity->fID = reply_id;
identity->fTTCIndex = reply_ttcIndex;
identity->fString.set(reply_text, reply_length);
}
return true;
}
bool ReadSkFontStyle(base::PickleIterator* iter, SkFontStyle* style) {
uint16_t reply_weight;
uint16_t reply_width;
uint16_t reply_slant;
if (!iter->ReadUInt16(&reply_weight) ||
!iter->ReadUInt16(&reply_width) ||
!iter->ReadUInt16(&reply_slant))
return false;
if (style) {
*style = SkFontStyle(reply_weight,
reply_width,
static_cast<SkFontStyle::Slant>(reply_slant));
}
return true;
}
void WriteSkString(base::Pickle* pickle, const SkString& str) {
pickle->WriteData(str.c_str(), str.size());
}
void WriteSkFontIdentity(base::Pickle* pickle,
const SkFontConfigInterface::FontIdentity& identity) {
pickle->WriteUInt32(identity.fID);
pickle->WriteUInt32(identity.fTTCIndex);
WriteSkString(pickle, identity.fString);
}
void WriteSkFontStyle(base::Pickle* pickle, SkFontStyle style) {
pickle->WriteUInt16(style.weight());
pickle->WriteUInt16(style.width());
pickle->WriteUInt16(style.slant());
}
bool SkBitmapToN32OpaqueOrPremul(const SkBitmap& in, SkBitmap* out) {
DCHECK(out);
const SkImageInfo& info = in.info();
if (info.colorType() == kN32_SkColorType &&
(info.alphaType() == kPremul_SkAlphaType ||
info.alphaType() == kOpaque_SkAlphaType)) {
// Shallow copy if the data is already in the right format.
*out = in;
return true;
}
SkImageInfo new_info =
info.makeColorType(kN32_SkColorType)
.makeAlphaType(info.alphaType() == kOpaque_SkAlphaType
? kOpaque_SkAlphaType
: kPremul_SkAlphaType);
if (!out->tryAllocPixels(new_info, 0)) {
return false;
}
if (!in.readPixels(out->pixmap())) {
return false;
}
return true;
}
} // namespace skia