晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
| DIR:/opt/alt/libharu/usr/share/libharu/bindings/python/demo/ |
| Current File : //opt/alt/libharu/usr/share/libharu/bindings/python/demo/grid_sheet.py |
###
## * << Haru Free PDF Library 2.0.0 >> -- grid_sheet.c
## *
## * Copyright (c) 1999-2006 Takeshi Kanno <takeshi_kanno@est.hi-ho.ne.jp>
## *
## * Permission to use, copy, modify, distribute and sell this software
## * and its documentation for any purpose is hereby granted without fee,
## * provided that the above copyright notice appear in all copies and
## * that both that copyright notice and this permission notice appear
## * in supporting documentation.
## * It is provided "as is" without express or implied warranty.
## *
##
## port to python by Li Jun
## http://groups.google.com/group/pythoncia
import os, sys
from ctypes import *
up=2
def setlibpath(up):
import sys
path=os.path.normpath(os.path.split(os.path.realpath(__file__))[0]+'\..'*up)
if path not in sys.path:
sys.path.append(path)
setlibpath(up)
from haru import *
from haru.c_func import *
from haru.hpdf_errorcode import *
@HPDF_Error_Handler(None, HPDF_UINT, HPDF_UINT, c_void_p)
def error_handler (error_no, detail_no, user_data):
global pdf
printf ("ERROR: %s, detail_no=%u\n", error_detail[error_no],
detail_no)
HPDF_Free (pdf)
sys.exit(1)
def print_grid (pdf, page):
height = HPDF_Page_GetHeight (page)
width = HPDF_Page_GetWidth (page)
font = HPDF_GetFont (pdf, "Helvetica", NULL)
HPDF_Page_SetFontAndSize (page, font, 5)
HPDF_Page_SetGrayFill (page, 0.5)
HPDF_Page_SetGrayStroke (page, 0.8)
# Draw horizontal lines
y = 0
while (y < height):
if (y % 10 == 0):
HPDF_Page_SetLineWidth (page, 0.5)
else:
if (HPDF_Page_GetLineWidth (page) != 0.25):
HPDF_Page_SetLineWidth (page, 0.25)
HPDF_Page_MoveTo (page, 0, y)
HPDF_Page_LineTo (page, width, y)
HPDF_Page_Stroke (page)
if (y % 10 == 0 and y > 0):
HPDF_Page_SetGrayStroke (page, 0.5)
HPDF_Page_MoveTo (page, 0, y)
HPDF_Page_LineTo (page, 5, y)
HPDF_Page_Stroke (page)
HPDF_Page_SetGrayStroke (page, 0.8)
y += 5
# Draw vertical lines
x = 0
while (x < width):
if (x % 10 == 0):
HPDF_Page_SetLineWidth (page, 0.5)
else:
if (HPDF_Page_GetLineWidth (page) != 0.25):
HPDF_Page_SetLineWidth (page, 0.25)
HPDF_Page_MoveTo (page, x, 0)
HPDF_Page_LineTo (page, x, height)
HPDF_Page_Stroke (page)
if (x % 50 == 0 and x > 0):
HPDF_Page_SetGrayStroke (page, 0.5)
HPDF_Page_MoveTo (page, x, 0)
HPDF_Page_LineTo (page, x, 5)
HPDF_Page_Stroke (page)
HPDF_Page_MoveTo (page, x, height)
HPDF_Page_LineTo (page, x, height - 5)
HPDF_Page_Stroke (page)
HPDF_Page_SetGrayStroke (page, 0.8)
x += 5
# Draw horizontal text
y = 0
while (y < height):
if (y % 10 == 0 and y > 0):
HPDF_Page_BeginText (page)
HPDF_Page_MoveTextPos (page, 5, y - 2)
buf="%u" % y
HPDF_Page_ShowText (page, buf)
HPDF_Page_EndText (page)
y += 5
# Draw vertical text
x = 0
while (x < width):
if (x % 50 == 0 and x > 0):
HPDF_Page_BeginText (page)
HPDF_Page_MoveTextPos (page, x, 5)
buf="%u" % x
HPDF_Page_ShowText (page, buf)
HPDF_Page_EndText (page)
HPDF_Page_BeginText (page)
HPDF_Page_MoveTextPos (page, x, height - 10)
HPDF_Page_ShowText (page, buf)
HPDF_Page_EndText (page)
x += 5
HPDF_Page_SetGrayFill (page, 0)
HPDF_Page_SetGrayStroke (page, 0)
def main():
global pdf
fname=os.path.realpath(sys.argv[0])
fname=fname[:fname.rfind('.')]+'.pdf'
pdf = HPDF_New (error_handler, NULL)
if (not pdf):
printf ("error: cannot create PdfDoc object\n")
return 1
# add a new page object.
page = HPDF_AddPage (pdf)
HPDF_Page_SetHeight (page, 600)
HPDF_Page_SetWidth (page, 400)
print_grid (pdf, page)
# save the document to a file
HPDF_SaveToFile (pdf, fname)
# clean up
HPDF_Free (pdf)
return 0
if __name__=='__main__':
main()
__all__=['print_grid'] |