Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
a7f15959
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看板
提交
a7f15959
编写于
11月 14, 2017
作者:
B
Behdad Esfahbod
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Shuffle
上级
a85d7ead
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
38 addition
and
38 deletion
+38
-38
src/hb-ot-hmtx-table.hh
src/hb-ot-hmtx-table.hh
+38
-38
未找到文件。
src/hb-ot-hmtx-table.hh
浏览文件 @
a7f15959
...
@@ -67,20 +67,14 @@ struct hmtxvmtx
...
@@ -67,20 +67,14 @@ struct hmtxvmtx
struct
accelerator_t
struct
accelerator_t
{
{
const
hmtxvmtx
*
table
;
hb_blob_t
*
blob
;
const
HVARVVAR
*
var
;
hb_blob_t
*
var_blob
;
inline
void
init
(
hb_face_t
*
face
,
inline
void
init
(
hb_face_t
*
face
,
hb_tag_t
_hea_tag
,
hb_tag_t
_hea_tag
,
hb_tag_t
_mtx_tag
,
hb_tag_t
_mtx_tag
,
hb_tag_t
_var_tag
,
hb_tag_t
_var_tag
,
hb_tag_t
os2_tag
,
hb_tag_t
os2_tag
,
unsigned
int
default_advance
=
0
)
unsigned
int
default_advance
_
=
0
)
{
{
this
->
default_advance
=
default_advance
?
default_advance
:
face
->
get_upem
();
default_advance
=
default_advance_
?
default_advance_
:
face
->
get_upem
();
bool
got_font_extents
=
false
;
bool
got_font_extents
=
false
;
if
(
os2_tag
)
if
(
os2_tag
)
...
@@ -90,72 +84,72 @@ struct hmtxvmtx
...
@@ -90,72 +84,72 @@ struct hmtxvmtx
#define USE_TYPO_METRICS (1u<<7)
#define USE_TYPO_METRICS (1u<<7)
if
(
0
!=
(
os2_table
->
fsSelection
&
USE_TYPO_METRICS
))
if
(
0
!=
(
os2_table
->
fsSelection
&
USE_TYPO_METRICS
))
{
{
this
->
ascender
=
os2_table
->
sTypoAscender
;
ascender
=
os2_table
->
sTypoAscender
;
this
->
descender
=
os2_table
->
sTypoDescender
;
descender
=
os2_table
->
sTypoDescender
;
this
->
line_gap
=
os2_table
->
sTypoLineGap
;
line_gap
=
os2_table
->
sTypoLineGap
;
got_font_extents
=
(
this
->
ascender
|
this
->
descender
)
!=
0
;
got_font_extents
=
(
ascender
|
descender
)
!=
0
;
}
}
hb_blob_destroy
(
os2_blob
);
hb_blob_destroy
(
os2_blob
);
}
}
hb_blob_t
*
_hea_blob
=
Sanitizer
<
_hea
>::
sanitize
(
face
->
reference_table
(
_hea_tag
));
hb_blob_t
*
_hea_blob
=
Sanitizer
<
_hea
>::
sanitize
(
face
->
reference_table
(
_hea_tag
));
const
_hea
*
_hea_table
=
Sanitizer
<
_hea
>::
lock_instance
(
_hea_blob
);
const
_hea
*
_hea_table
=
Sanitizer
<
_hea
>::
lock_instance
(
_hea_blob
);
this
->
num_advances
=
_hea_table
->
numberOfLongMetrics
;
num_advances
=
_hea_table
->
numberOfLongMetrics
;
if
(
!
got_font_extents
)
if
(
!
got_font_extents
)
{
{
this
->
ascender
=
_hea_table
->
ascender
;
ascender
=
_hea_table
->
ascender
;
this
->
descender
=
_hea_table
->
descender
;
descender
=
_hea_table
->
descender
;
this
->
line_gap
=
_hea_table
->
lineGap
;
line_gap
=
_hea_table
->
lineGap
;
got_font_extents
=
(
this
->
ascender
|
this
->
descender
)
!=
0
;
got_font_extents
=
(
ascender
|
descender
)
!=
0
;
}
}
hb_blob_destroy
(
_hea_blob
);
hb_blob_destroy
(
_hea_blob
);
this
->
has_font_extents
=
got_font_extents
;
has_font_extents
=
got_font_extents
;
this
->
blob
=
Sanitizer
<
hmtxvmtx
>::
sanitize
(
face
->
reference_table
(
_mtx_tag
));
blob
=
Sanitizer
<
hmtxvmtx
>::
sanitize
(
face
->
reference_table
(
_mtx_tag
));
/* Cap num_metrics() and num_advances() based on table length. */
/* Cap num_metrics() and num_advances() based on table length. */
unsigned
int
len
=
hb_blob_get_length
(
this
->
blob
);
unsigned
int
len
=
hb_blob_get_length
(
blob
);
if
(
unlikely
(
this
->
num_advances
*
4
>
len
))
if
(
unlikely
(
num_advances
*
4
>
len
))
this
->
num_advances
=
len
/
4
;
num_advances
=
len
/
4
;
this
->
num_metrics
=
this
->
num_advances
+
(
len
-
4
*
this
->
num_advances
)
/
2
;
num_metrics
=
num_advances
+
(
len
-
4
*
num_advances
)
/
2
;
/* We MUST set num_metrics to zero if num_advances is zero.
/* We MUST set num_metrics to zero if num_advances is zero.
* Our get_advance() depends on that. */
* Our get_advance() depends on that. */
if
(
unlikely
(
!
this
->
num_advances
))
if
(
unlikely
(
!
num_advances
))
{
{
this
->
num_metrics
=
this
->
num_advances
=
0
;
num_metrics
=
num_advances
=
0
;
hb_blob_destroy
(
this
->
blob
);
hb_blob_destroy
(
blob
);
this
->
blob
=
hb_blob_get_empty
();
blob
=
hb_blob_get_empty
();
}
}
t
his
->
table
=
Sanitizer
<
hmtxvmtx
>::
lock_instance
(
this
->
blob
);
t
able
=
Sanitizer
<
hmtxvmtx
>::
lock_instance
(
blob
);
this
->
var_blob
=
Sanitizer
<
HVARVVAR
>::
sanitize
(
face
->
reference_table
(
_var_tag
));
var_blob
=
Sanitizer
<
HVARVVAR
>::
sanitize
(
face
->
reference_table
(
_var_tag
));
this
->
var
=
Sanitizer
<
HVARVVAR
>::
lock_instance
(
this
->
var_blob
);
var_table
=
Sanitizer
<
HVARVVAR
>::
lock_instance
(
var_blob
);
}
}
inline
void
fini
(
void
)
inline
void
fini
(
void
)
{
{
hb_blob_destroy
(
this
->
blob
);
hb_blob_destroy
(
blob
);
hb_blob_destroy
(
this
->
var_blob
);
hb_blob_destroy
(
var_blob
);
}
}
inline
unsigned
int
get_advance
(
hb_codepoint_t
glyph
,
inline
unsigned
int
get_advance
(
hb_codepoint_t
glyph
,
hb_font_t
*
font
)
const
hb_font_t
*
font
)
const
{
{
if
(
unlikely
(
glyph
>=
this
->
num_metrics
))
if
(
unlikely
(
glyph
>=
num_metrics
))
{
{
/* If
this->
num_metrics is zero, it means we don't have the metrics table
/* If num_metrics is zero, it means we don't have the metrics table
* for this direction: return default advance. Otherwise, it means that the
* for this direction: return default advance. Otherwise, it means that the
* glyph index is out of bound: return zero. */
* glyph index is out of bound: return zero. */
if
(
this
->
num_metrics
)
if
(
num_metrics
)
return
0
;
return
0
;
else
else
return
this
->
default_advance
;
return
default_advance
;
}
}
return
t
his
->
table
->
longMetric
[
MIN
(
glyph
,
(
uint32_t
)
this
->
num_advances
-
1
)].
advance
return
t
able
->
longMetric
[
MIN
(
glyph
,
(
uint32_t
)
num_advances
-
1
)].
advance
+
this
->
var
->
get_advance_var
(
glyph
,
font
->
coords
,
font
->
num_coords
);
// TODO Optimize?!
+
var_table
->
get_advance_var
(
glyph
,
font
->
coords
,
font
->
num_coords
);
// TODO Optimize?!
}
}
public:
public:
...
@@ -163,10 +157,16 @@ struct hmtxvmtx
...
@@ -163,10 +157,16 @@ struct hmtxvmtx
unsigned
short
ascender
;
unsigned
short
ascender
;
unsigned
short
descender
;
unsigned
short
descender
;
unsigned
short
line_gap
;
unsigned
short
line_gap
;
private:
private:
unsigned
int
num_metrics
;
unsigned
int
num_metrics
;
unsigned
int
num_advances
;
unsigned
int
num_advances
;
unsigned
int
default_advance
;
unsigned
int
default_advance
;
const
hmtxvmtx
*
table
;
hb_blob_t
*
blob
;
const
HVARVVAR
*
var_table
;
hb_blob_t
*
var_blob
;
};
};
protected:
protected:
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录