Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
d3684141
T
Third Party Harfbuzz
项目概览
OpenHarmony
/
Third Party Harfbuzz
1 年多 前同步成功
通知
0
Star
18
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
Third Party Harfbuzz
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
d3684141
编写于
2月 15, 2018
作者:
G
Garret Rieger
提交者:
Behdad Esfahbod
2月 16, 2018
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[subset] add helper methods to glyf accelerator for reading composite glyph information.
上级
926db874
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
112 addition
and
3 deletion
+112
-3
src/hb-ot-glyf-table.hh
src/hb-ot-glyf-table.hh
+112
-3
未找到文件。
src/hb-ot-glyf-table.hh
浏览文件 @
d3684141
...
...
@@ -81,9 +81,9 @@ struct glyf
struct
GlyphHeader
{
HBINT16
numberOfContours
;
/* If the number of contours is
* greater than or equal to zero,
* this is a simple glyph; if negative,
* this is a composite glyph. */
* greater than or equal to zero,
* this is a simple glyph; if negative,
* this is a composite glyph. */
FWORD
xMin
;
/* Minimum x for coordinate data. */
FWORD
yMin
;
/* Minimum y for coordinate data. */
FWORD
xMax
;
/* Maximum x for coordinate data. */
...
...
@@ -92,6 +92,50 @@ struct glyf
DEFINE_SIZE_STATIC
(
10
);
};
struct
CompositeGlyphHeader
{
static
const
uint16_t
ARG_1_AND_2_ARE_WORDS
=
0x0001
;
static
const
uint16_t
ARGS_ARE_XY_VALUES
=
0x0002
;
static
const
uint16_t
ROUND_XY_TO_GRID
=
0x0004
;
static
const
uint16_t
WE_HAVE_A_SCALE
=
0x0008
;
static
const
uint16_t
MORE_COMPONENTS
=
0x0020
;
static
const
uint16_t
WE_HAVE_AN_X_AND_Y_SCALE
=
0x0040
;
static
const
uint16_t
WE_HAVE_A_TWO_BY_TWO
=
0x0080
;
static
const
uint16_t
WE_HAVE_INSTRUCTIONS
=
0x0100
;
static
const
uint16_t
USE_MY_METRICS
=
0x0200
;
static
const
uint16_t
OVERLAP_COMPOUND
=
0x0400
;
static
const
uint16_t
SCALED_COMPONENT_OFFSET
=
0x0800
;
static
const
uint16_t
UNSCALED_COMPONENT_OFFSET
=
0x1000
;
HBUINT16
flags
;
HBUINT16
glyphIndex
;
inline
unsigned
int
get_size
(
void
)
const
{
unsigned
int
size
=
min_size
;
if
(
flags
&
ARG_1_AND_2_ARE_WORDS
)
{
// arg1 and 2 are int16
size
+=
4
;
}
else
{
// arg1 and 2 are int8
size
+=
2
;
}
if
(
flags
&
WE_HAVE_A_SCALE
)
{
// One x 16 bit (scale)
size
+=
2
;
}
else
if
(
flags
&
WE_HAVE_AN_X_AND_Y_SCALE
)
{
// Two x 16 bit (xscale, yscale)
size
+=
4
;
}
else
if
(
flags
&
WE_HAVE_A_TWO_BY_TWO
)
{
// Four x 16 bit (xscale, scale01, scale10, yscale)
size
+=
8
;
}
return
size
;
}
DEFINE_SIZE_MIN
(
4
);
};
struct
accelerator_t
{
inline
void
init
(
hb_face_t
*
face
)
...
...
@@ -122,6 +166,71 @@ struct glyf
hb_blob_destroy
(
glyf_blob
);
}
inline
bool
in_table
(
const
char
*
offset
,
unsigned
int
len
)
const
{
return
(
offset
-
(
const
char
*
)
glyf_table
+
len
)
<=
glyf_len
;
}
inline
bool
in_table
(
const
CompositeGlyphHeader
*
header
)
const
{
return
in_table
((
const
char
*
)
header
,
CompositeGlyphHeader
::
min_size
)
&&
in_table
((
const
char
*
)
header
,
header
->
get_size
());
}
inline
bool
in_glyph
(
const
CompositeGlyphHeader
*
header
,
unsigned
int
start_offset
,
unsigned
int
end_offset
)
{
do
{
unsigned
int
offset_in_glyf
=
(
const
char
*
)
header
-
(
const
char
*
)
glyf_table
;
if
(
offset_in_glyf
<
start_offset
||
offset_in_glyf
+
header
->
get_size
()
>
end_offset
)
return
false
;
}
while
(
next_composite
(
&
header
));
return
true
;
}
/*
* Returns true if the referenced glyph is a valid glyph and a composite glyph.
* If true is returned a pointer to the composite glyph will be written into
* composite.
*/
inline
bool
get_composite
(
hb_codepoint_t
glyph
,
const
CompositeGlyphHeader
**
composite
/* OUT */
)
{
unsigned
int
start_offset
,
end_offset
;
if
(
!
get_offsets
(
glyph
,
&
start_offset
,
&
end_offset
))
return
false
;
/* glyph not found */
if
(
end_offset
-
start_offset
<
GlyphHeader
::
static_size
)
return
false
;
/* Empty glyph; zero extents. */
const
GlyphHeader
&
glyph_header
=
StructAtOffset
<
GlyphHeader
>
(
glyf_table
,
start_offset
);
if
(
glyph_header
.
numberOfContours
<
0
)
{
const
CompositeGlyphHeader
*
possible
=
&
StructAfter
<
CompositeGlyphHeader
,
GlyphHeader
>
(
glyph_header
);
if
(
!
in_table
(
possible
)
||
!
in_glyph
(
possible
,
start_offset
,
end_offset
))
return
false
;
*
composite
=
possible
;
return
true
;
}
return
false
;
}
inline
bool
next_composite
(
const
CompositeGlyphHeader
**
next
/* IN/OUT */
)
const
{
if
((
*
next
)
->
flags
&
CompositeGlyphHeader
::
MORE_COMPONENTS
)
{
const
CompositeGlyphHeader
*
possible
=
&
StructAfter
<
CompositeGlyphHeader
,
CompositeGlyphHeader
>
(
**
next
);
if
(
!
in_table
(
possible
))
return
false
;
*
next
=
possible
;
return
true
;
}
return
false
;
}
inline
bool
get_offsets
(
hb_codepoint_t
glyph
,
unsigned
int
*
start_offset
/* OUT */
,
unsigned
int
*
end_offset
/* OUT */
)
const
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录