Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
3b0bb855
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看板
提交
3b0bb855
编写于
5月 20, 2011
作者:
B
Behdad Esfahbod
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[Vertical] GPOS x/y advance adjustments only apply in hori/vert respectively
上级
cc2086d6
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
21 addition
and
10 deletion
+21
-10
src/hb-ot-layout-gpos-private.hh
src/hb-ot-layout-gpos-private.hh
+21
-10
未找到文件。
src/hb-ot-layout-gpos-private.hh
浏览文件 @
3b0bb855
...
...
@@ -95,20 +95,26 @@ struct ValueFormat : USHORT
{
return
get_len
()
*
Value
::
static_size
;
}
void
apply_value
(
hb_font_t
*
font
,
hb_direction_t
direction
,
const
void
*
base
,
const
Value
*
values
,
hb_glyph_position_t
&
glyph_pos
)
const
{
unsigned
int
x_ppem
,
y_ppem
;
unsigned
int
format
=
*
this
;
hb_bool_t
horizontal
=
HB_DIRECTION_IS_HORIZONTAL
(
direction
);
if
(
!
format
)
return
;
if
(
format
&
xPlacement
)
glyph_pos
.
x_offset
+=
font
->
em_scale_x
(
get_short
(
values
++
));
if
(
format
&
yPlacement
)
glyph_pos
.
y_offset
+=
font
->
em_scale_y
(
get_short
(
values
++
));
if
(
format
&
xAdvance
)
glyph_pos
.
x_advance
+=
font
->
em_scale_x
(
get_short
(
values
++
));
if
(
format
&
xAdvance
)
{
if
(
likely
(
horizontal
))
glyph_pos
.
x_advance
+=
font
->
em_scale_x
(
get_short
(
values
++
));
else
values
++
;
}
/* y_advance values grow downward but font-space grows upward, hence negation */
if
(
format
&
yAdvance
)
glyph_pos
.
y_advance
-=
font
->
em_scale_y
(
get_short
(
values
++
));
if
(
format
&
yAdvance
)
{
if
(
unlikely
(
!
horizontal
))
glyph_pos
.
y_advance
-=
font
->
em_scale_y
(
get_short
(
values
++
));
else
values
++
;
}
if
(
!
has_device
())
return
;
...
...
@@ -125,11 +131,11 @@ struct ValueFormat : USHORT
if
(
y_ppem
)
glyph_pos
.
y_offset
+=
(
base
+
get_device
(
values
++
)).
get_y_delta
(
font
);
else
values
++
;
}
if
(
format
&
xAdvDevice
)
{
if
(
x_ppem
)
glyph_pos
.
x_advance
+=
(
base
+
get_device
(
values
++
)).
get_x_delta
(
font
);
else
values
++
;
if
(
horizontal
&&
x_ppem
)
glyph_pos
.
x_advance
+=
(
base
+
get_device
(
values
++
)).
get_x_delta
(
font
);
else
values
++
;
}
if
(
format
&
yAdvDevice
)
{
/* y_advance values grow downward but font-space grows upward, hence negation */
if
(
y_ppem
)
glyph_pos
.
y_advance
-=
(
base
+
get_device
(
values
++
)).
get_y_delta
(
font
);
else
values
++
;
if
(
!
horizontal
&&
y_ppem
)
glyph_pos
.
y_advance
-=
(
base
+
get_device
(
values
++
)).
get_y_delta
(
font
);
else
values
++
;
}
}
...
...
@@ -436,7 +442,8 @@ struct SinglePosFormat1
if
(
likely
(
index
==
NOT_COVERED
))
return
false
;
valueFormat
.
apply_value
(
c
->
font
,
this
,
values
,
c
->
buffer
->
pos
[
c
->
buffer
->
i
]);
valueFormat
.
apply_value
(
c
->
font
,
c
->
direction
,
this
,
values
,
c
->
buffer
->
pos
[
c
->
buffer
->
i
]);
c
->
buffer
->
i
++
;
return
true
;
...
...
@@ -478,7 +485,7 @@ struct SinglePosFormat2
if
(
likely
(
index
>=
valueCount
))
return
false
;
valueFormat
.
apply_value
(
c
->
font
,
this
,
valueFormat
.
apply_value
(
c
->
font
,
c
->
direction
,
this
,
&
values
[
index
*
valueFormat
.
get_len
()],
c
->
buffer
->
pos
[
c
->
buffer
->
i
]);
...
...
@@ -574,8 +581,10 @@ struct PairSet
{
if
(
c
->
buffer
->
info
[
pos
].
codepoint
==
record
->
secondGlyph
)
{
valueFormats
[
0
].
apply_value
(
c
->
font
,
this
,
&
record
->
values
[
0
],
c
->
buffer
->
pos
[
c
->
buffer
->
i
]);
valueFormats
[
1
].
apply_value
(
c
->
font
,
this
,
&
record
->
values
[
len1
],
c
->
buffer
->
pos
[
pos
]);
valueFormats
[
0
].
apply_value
(
c
->
font
,
c
->
direction
,
this
,
&
record
->
values
[
0
],
c
->
buffer
->
pos
[
c
->
buffer
->
i
]);
valueFormats
[
1
].
apply_value
(
c
->
font
,
c
->
direction
,
this
,
&
record
->
values
[
len1
],
c
->
buffer
->
pos
[
pos
]);
if
(
len2
)
pos
++
;
c
->
buffer
->
i
=
pos
;
...
...
@@ -709,8 +718,10 @@ struct PairPosFormat2
return
false
;
const
Value
*
v
=
&
values
[
record_len
*
(
klass1
*
class2Count
+
klass2
)];
valueFormat1
.
apply_value
(
c
->
font
,
this
,
v
,
c
->
buffer
->
pos
[
c
->
buffer
->
i
]);
valueFormat2
.
apply_value
(
c
->
font
,
this
,
v
+
len1
,
c
->
buffer
->
pos
[
j
]);
valueFormat1
.
apply_value
(
c
->
font
,
c
->
direction
,
this
,
v
,
c
->
buffer
->
pos
[
c
->
buffer
->
i
]);
valueFormat2
.
apply_value
(
c
->
font
,
c
->
direction
,
this
,
v
+
len1
,
c
->
buffer
->
pos
[
j
]);
if
(
len2
)
j
++
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录