Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
e8fd8393
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看板
提交
e8fd8393
编写于
4月 09, 2015
作者:
B
Behdad Esfahbod
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[util/hb-view] Fix rendering with all combinations of negative scales
上级
69d5af93
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
47 addition
and
45 deletion
+47
-45
util/view-cairo.cc
util/view-cairo.cc
+47
-43
util/view-cairo.hh
util/view-cairo.hh
+0
-2
未找到文件。
util/view-cairo.cc
浏览文件 @
e8fd8393
...
@@ -26,69 +26,71 @@
...
@@ -26,69 +26,71 @@
#include "view-cairo.hh"
#include "view-cairo.hh"
#include <assert.h>
void
void
view_cairo_t
::
get_surface_size
(
cairo_scaled_font_t
*
scaled_font
,
view_cairo_t
::
render
(
const
font_options_t
*
font_opts
)
double
*
w
,
double
*
h
)
{
{
cairo_font_extents_t
font_extents
;
bool
vertical
=
HB_DIRECTION_IS_VERTICAL
(
direction
);
int
vert
=
vertical
?
1
:
0
;
int
horiz
=
vertical
?
0
:
1
;
cairo_scaled_font_extents
(
scaled_font
,
&
font_extents
);
int
x_sign
=
font_opts
->
font_size_x
<
0
?
-
1
:
+
1
;
int
y_sign
=
font_opts
->
font_size_y
<
0
?
-
1
:
+
1
;
bool
vertical
=
HB_DIRECTION_IS_VERTICAL
(
direction
);
cairo_scaled_font_t
*
scaled_font
=
helper_cairo_create_scaled_font
(
font_opts
);
(
vertical
?
*
w
:
*
h
)
=
(
int
)
lines
->
len
*
(
font_extents
.
height
+
view_options
.
line_space
)
-
view_options
.
line_space
;
cairo_font_extents_t
font_extents
;
(
vertical
?
*
h
:
*
w
)
=
0
;
cairo_scaled_font_extents
(
scaled_font
,
&
font_extents
);
/* Looks like cairo doesn't negate the sign of font extents even if
* y_scale is negative. This is probably a bug, but that's the way
* it is, and we code for it. Assert, just in case this accidentally
* changes in the future (or is different on non-FreeType cairo font
* backends. */
assert
(
font_extents
.
height
>=
0
);
double
leading
=
font_extents
.
height
+
view_options
.
line_space
;
/* Calculate surface size. */
double
w
,
h
;
(
vertical
?
w
:
h
)
=
(
int
)
lines
->
len
*
leading
-
view_options
.
line_space
;
(
vertical
?
h
:
w
)
=
0
;
for
(
unsigned
int
i
=
0
;
i
<
lines
->
len
;
i
++
)
{
for
(
unsigned
int
i
=
0
;
i
<
lines
->
len
;
i
++
)
{
helper_cairo_line_t
&
line
=
g_array_index
(
lines
,
helper_cairo_line_t
,
i
);
helper_cairo_line_t
&
line
=
g_array_index
(
lines
,
helper_cairo_line_t
,
i
);
double
x_advance
,
y_advance
;
double
x_advance
,
y_advance
;
line
.
get_advance
(
&
x_advance
,
&
y_advance
);
line
.
get_advance
(
&
x_advance
,
&
y_advance
);
if
(
vertical
)
if
(
vertical
)
*
h
=
MAX
(
*
h
,
y_advance
);
h
=
MAX
(
h
,
y_sign
*
y_advance
);
else
else
*
w
=
MAX
(
*
w
,
x_advance
);
w
=
MAX
(
w
,
x_sign
*
x_advance
);
}
}
*
w
+=
view_options
.
margin
.
l
+
view_options
.
margin
.
r
;
/* Create surface. */
*
h
+=
view_options
.
margin
.
t
+
view_options
.
margin
.
b
;
cairo_t
*
cr
=
helper_cairo_create_context
(
w
+
view_options
.
margin
.
l
+
view_options
.
margin
.
r
,
}
h
+
view_options
.
margin
.
t
+
view_options
.
margin
.
b
,
&
view_options
,
&
output_options
);
void
view_cairo_t
::
render
(
const
font_options_t
*
font_opts
)
{
cairo_scaled_font_t
*
scaled_font
=
helper_cairo_create_scaled_font
(
font_opts
);
double
w
,
h
;
get_surface_size
(
scaled_font
,
&
w
,
&
h
);
cairo_t
*
cr
=
helper_cairo_create_context
(
w
,
h
,
&
view_options
,
&
output_options
);
cairo_set_scaled_font
(
cr
,
scaled_font
);
cairo_set_scaled_font
(
cr
,
scaled_font
);
cairo_scaled_font_destroy
(
scaled_font
);
draw
(
cr
);
helper_cairo_destroy_context
(
cr
);
}
void
view_cairo_t
::
draw
(
cairo_t
*
cr
)
{
cairo_save
(
cr
);
bool
vertical
=
HB_DIRECTION_IS_VERTICAL
(
direction
);
/* Setup coordinate system. */
int
v
=
vertical
?
1
:
0
;
int
h
=
vertical
?
0
:
1
;
cairo_font_extents_t
font_extents
;
cairo_font_extents
(
cr
,
&
font_extents
);
cairo_translate
(
cr
,
view_options
.
margin
.
l
,
view_options
.
margin
.
t
);
cairo_translate
(
cr
,
view_options
.
margin
.
l
,
view_options
.
margin
.
t
);
if
(
vertical
)
if
(
vertical
)
cairo_translate
(
cr
,
font_extents
.
height
*
(
lines
->
len
+
.5
),
0
);
cairo_translate
(
cr
,
w
/* We stack lines right to left */
-
font_extents
.
height
*
.5
/* "ascent" for vertical */
,
y_sign
<
0
?
h
:
0
);
else
else
cairo_translate
(
cr
,
0
,
-
(
font_extents
.
height
-
font_extents
.
ascent
));
{
cairo_translate
(
cr
,
x_sign
<
0
?
w
:
0
,
y_sign
<
0
?
font_extents
.
descent
:
font_extents
.
ascent
);
}
/* Draw. */
cairo_translate
(
cr
,
+
vert
*
leading
,
-
horiz
*
leading
);
for
(
unsigned
int
i
=
0
;
i
<
lines
->
len
;
i
++
)
for
(
unsigned
int
i
=
0
;
i
<
lines
->
len
;
i
++
)
{
{
helper_cairo_line_t
&
l
=
g_array_index
(
lines
,
helper_cairo_line_t
,
i
);
helper_cairo_line_t
&
l
=
g_array_index
(
lines
,
helper_cairo_line_t
,
i
);
if
(
i
)
cairo_translate
(
cr
,
-
vert
*
leading
,
+
horiz
*
leading
);
cairo_translate
(
cr
,
v
*
-
view_options
.
line_space
,
h
*
view_options
.
line_space
);
cairo_translate
(
cr
,
v
*
-
font_extents
.
height
,
h
*
font_extents
.
height
);
if
(
view_options
.
annotate
)
{
if
(
view_options
.
annotate
)
{
cairo_save
(
cr
);
cairo_save
(
cr
);
...
@@ -120,5 +122,7 @@ view_cairo_t::draw (cairo_t *cr)
...
@@ -120,5 +122,7 @@ view_cairo_t::draw (cairo_t *cr)
cairo_show_glyphs
(
cr
,
l
.
glyphs
,
l
.
num_glyphs
);
cairo_show_glyphs
(
cr
,
l
.
glyphs
,
l
.
num_glyphs
);
}
}
cairo_restore
(
cr
);
/* Clean up. */
helper_cairo_destroy_context
(
cr
);
cairo_scaled_font_destroy
(
scaled_font
);
}
}
util/view-cairo.hh
浏览文件 @
e8fd8393
...
@@ -95,8 +95,6 @@ struct view_cairo_t
...
@@ -95,8 +95,6 @@ struct view_cairo_t
view_options_t
view_options
;
view_options_t
view_options
;
void
render
(
const
font_options_t
*
font_opts
);
void
render
(
const
font_options_t
*
font_opts
);
void
get_surface_size
(
cairo_scaled_font_t
*
scaled_font
,
double
*
w
,
double
*
h
);
void
draw
(
cairo_t
*
cr
);
hb_direction_t
direction
;
// Remove this, make segment_properties accessible
hb_direction_t
direction
;
// Remove this, make segment_properties accessible
GArray
*
lines
;
GArray
*
lines
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录