Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
bfffe85d
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看板
提交
bfffe85d
编写于
8月 14, 2019
作者:
E
Ebrahim Byagowi
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[opbd] Use multiformat convention on the table
上级
d6206dbc
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
89 addition
and
27 deletion
+89
-27
src/hb-aat-layout-opbd-table.hh
src/hb-aat-layout-opbd-table.hh
+89
-27
未找到文件。
src/hb-aat-layout-opbd-table.hh
浏览文件 @
bfffe85d
...
@@ -53,42 +53,104 @@ struct OpticalBounds
...
@@ -53,42 +53,104 @@ struct OpticalBounds
DEFINE_SIZE_STATIC
(
8
);
DEFINE_SIZE_STATIC
(
8
);
};
};
struct
opbd
struct
opbd
Format0
{
{
static
constexpr
hb_tag_t
tableTag
=
HB_AAT_TAG_opbd
;
bool
get_bounds
(
hb_font_t
*
font
,
hb_codepoint_t
glyph_id
,
hb_glyph_extents_t
*
extents
,
const
void
*
base
)
const
{
const
OffsetTo
<
OpticalBounds
>
*
bounds_offset
=
lookupTable
.
get_value
(
glyph_id
,
font
->
face
->
get_num_glyphs
());
if
(
!
bounds_offset
)
return
false
;
const
OpticalBounds
&
bounds
=
base
+*
bounds_offset
;
if
(
extents
)
*
extents
=
{
font
->
em_scale_x
(
bounds
.
leftSide
),
font
->
em_scale_y
(
bounds
.
topSide
),
font
->
em_scale_x
(
bounds
.
rightSide
),
font
->
em_scale_y
(
bounds
.
bottomSide
)
};
return
true
;
}
bool
sanitize
(
hb_sanitize_context_t
*
c
,
const
void
*
base
)
const
{
TRACE_SANITIZE
(
this
);
return_trace
(
likely
(
c
->
check_struct
(
this
)
&&
lookupTable
.
sanitize
(
c
,
base
)));
}
protected:
Lookup
<
OffsetTo
<
OpticalBounds
>>
lookupTable
;
/* Lookup table associating glyphs with the four
* int16 values for the left-side, top-side,
* right-side, and bottom-side optical bounds. */
public:
DEFINE_SIZE_MIN
(
2
);
};
bool
get_optical_bounds
(
hb_font_t
*
font
,
hb_codepoint_t
glyph_id
,
struct
opbdFormat1
hb_position_t
*
left
,
hb_position_t
*
top
,
{
hb_position_t
*
right
,
hb_position_t
*
bottom
)
const
bool
get_bounds
(
hb_font_t
*
font
,
hb_codepoint_t
glyph_id
,
hb_glyph_extents_t
*
extents
,
const
void
*
base
)
const
{
{
const
OffsetTo
<
OpticalBounds
>
*
bounds_offset
=
lookupTable
.
get_value
(
glyph_id
,
font
->
face
->
get_num_glyphs
());
const
OffsetTo
<
OpticalBounds
>
*
bounds_offset
=
lookupTable
.
get_value
(
glyph_id
,
font
->
face
->
get_num_glyphs
());
if
(
!
bounds_offset
)
return
false
;
if
(
!
bounds_offset
)
return
false
;
const
OpticalBounds
&
bounds
=
this
+*
bounds_offset
;
const
OpticalBounds
&
bounds
=
base
+*
bounds_offset
;
switch
(
format
)
hb_position_t
left
=
0
,
top
=
0
,
right
=
0
,
bottom
=
0
,
ignore
;
if
(
font
->
get_glyph_contour_point
(
glyph_id
,
bounds
.
leftSide
,
&
left
,
&
ignore
)
||
font
->
get_glyph_contour_point
(
glyph_id
,
bounds
.
topSide
,
&
ignore
,
&
top
)
||
font
->
get_glyph_contour_point
(
glyph_id
,
bounds
.
rightSide
,
&
right
,
&
ignore
)
||
font
->
get_glyph_contour_point
(
glyph_id
,
bounds
.
bottomSide
,
&
ignore
,
&
bottom
))
{
{
case
0
:
if
(
extents
)
*
left
=
font
->
em_scale_x
(
bounds
.
leftSide
);
*
extents
=
{
left
,
top
,
right
,
bottom
};
*
top
=
font
->
em_scale_y
(
bounds
.
topSide
);
*
right
=
font
->
em_scale_x
(
bounds
.
rightSide
);
*
bottom
=
font
->
em_scale_y
(
bounds
.
bottomSide
);
return
true
;
return
true
;
case
1
:
}
hb_position_t
ignore
;
return
false
;
return
font
->
get_glyph_contour_point
(
glyph_id
,
bounds
.
leftSide
,
left
,
&
ignore
)
&&
}
font
->
get_glyph_contour_point
(
glyph_id
,
bounds
.
topSide
,
&
ignore
,
top
)
&&
font
->
get_glyph_contour_point
(
glyph_id
,
bounds
.
rightSide
,
right
,
&
ignore
)
&&
bool
sanitize
(
hb_sanitize_context_t
*
c
,
const
void
*
base
)
const
font
->
get_glyph_contour_point
(
glyph_id
,
bounds
.
bottomSide
,
&
ignore
,
bottom
);
{
default:
TRACE_SANITIZE
(
this
);
return
false
;
return_trace
(
likely
(
c
->
check_struct
(
this
)
&&
lookupTable
.
sanitize
(
c
,
base
)));
}
protected:
Lookup
<
OffsetTo
<
OpticalBounds
>>
lookupTable
;
/* Lookup table associating glyphs with the four
* int16 values for the left-side, top-side,
* right-side, and bottom-side optical bounds. */
public:
DEFINE_SIZE_MIN
(
2
);
};
struct
opbd
{
static
constexpr
hb_tag_t
tableTag
=
HB_AAT_TAG_opbd
;
bool
get_bounds
(
hb_font_t
*
font
,
hb_codepoint_t
glyph_id
,
hb_glyph_extents_t
*
extents
)
const
{
switch
(
format
)
{
case
0
:
return
u
.
format0
.
get_bounds
(
font
,
glyph_id
,
extents
,
this
);
case
1
:
return
u
.
format1
.
get_bounds
(
font
,
glyph_id
,
extents
,
this
);
default:
return
false
;
}
}
}
}
bool
sanitize
(
hb_sanitize_context_t
*
c
)
const
bool
sanitize
(
hb_sanitize_context_t
*
c
)
const
{
{
TRACE_SANITIZE
(
this
);
TRACE_SANITIZE
(
this
);
return_trace
(
likely
(
c
->
check_struct
(
this
)
&&
if
(
unlikely
(
!
c
->
check_struct
(
this
)
||
version
.
major
!=
1
))
version
.
major
==
1
&&
return_trace
(
false
);
lookupTable
.
sanitize
(
c
,
this
)));
switch
(
format
)
{
case
0
:
return_trace
(
u
.
format0
.
sanitize
(
c
,
this
));
case
1
:
return_trace
(
u
.
format1
.
sanitize
(
c
,
this
));
default:
return_trace
(
true
);
}
}
}
protected:
protected:
...
@@ -97,10 +159,10 @@ struct opbd
...
@@ -97,10 +159,10 @@ struct opbd
HBUINT16
format
;
/* Format of the optical bounds table.
HBUINT16
format
;
/* Format of the optical bounds table.
* Format 0 indicates distance and Format 1 indicates
* Format 0 indicates distance and Format 1 indicates
* control point. */
* control point. */
Lookup
<
OffsetTo
<
OpticalBounds
>>
union
{
lookupTable
;
/* Lookup table associating glyphs with the four
opbdFormat0
format0
;
* int16 values for the left-side, top-side,
opbdFormat1
format1
;
* right-side, and bottom-side optical bounds. */
}
u
;
public:
public:
DEFINE_SIZE_MIN
(
8
);
DEFINE_SIZE_MIN
(
8
);
};
};
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录