/usr/share/doc/python-cairo/examples/warpedtext.py is in python-cairo 1.8.8-2.2.
This file is owned by root:root, with mode 0o755.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 | #!/usr/bin/env python
import cairo
import math
def warpPath(ctx, function):
first = True
for type, points in ctx.copy_path():
if type == cairo.PATH_MOVE_TO:
if first:
ctx.new_path()
first = False
x, y = function(*points)
ctx.move_to(x, y)
elif type == cairo.PATH_LINE_TO:
x, y = function(*points)
ctx.line_to(x, y)
elif type == cairo.PATH_CURVE_TO:
x1, y1, x2, y2, x3, y3 = points
x1, y1 = function(x1, y1)
x2, y2 = function(x2, y2)
x3, y3 = function(x3, y3)
ctx.curve_to(x1, y1, x2, y2, x3, y3)
elif type == cairo.PATH_CLOSE_PATH:
ctx.close_path()
def spiral(x, y):
theta0 = -math.pi * 3 / 4
theta = x / Width * math.pi * 2 + theta0
radius = y + 200 - x/7
xnew = radius*math.cos(theta)
ynew = radius*math.sin(-theta)
return xnew + Width/2, ynew + Height/2
def curl(x, y):
xn = x - Textwidth/2
#yn = y - Textheight/2
xnew = xn
ynew = y + xn ** 3 / ((Textwidth/2)**3) * 70
return xnew + Width/2, ynew + Height*2/5
Width, Height = 512, 512
surface = cairo.ImageSurface(cairo.FORMAT_ARGB32, Width, Height)
ctx = cairo.Context(surface)
solidpattern = ctx.get_source()
# background
pat = cairo.LinearGradient (0.0, 0.0, 0, Height)
pat.add_color_stop_rgba (1, 0, 0, 0, 1)
pat.add_color_stop_rgba (0, 1, 1, 1, 1)
ctx.rectangle (0,0,Width,Height)
ctx.set_source (pat)
ctx.fill ()
# foreground
ctx.set_source (solidpattern)
ctx.set_source_rgb (1,1,1)
ctx.select_font_face("Sans")
ctx.set_font_size(80)
# spiral text
ctx.new_path()
ctx.move_to(0, 0)
ctx.text_path("pycairo - " + "spam " * 5)
warpPath(ctx, spiral)
ctx.fill()
# curly text
ctx.new_path()
ctx.move_to(0, 0)
ctx.set_source_rgb(0.3, 0.3, 0.3)
text = "I am curly :)"
ctx.text_path(text)
Textwidth, Textheight = ctx.text_extents(text)[2:4]
warpPath(ctx, curl)
ctx.fill()
surface.write_to_png("warpedtext.png")
|