Прикреплённый файл «grap_6-0.py»
Загрузка 1 #!/usr/bin/env python
2 # -*- coding: UTF-8 -*-
3 '''
4 Проект "Построение графика", версия 5 (эпоха 2)
5 Построение графика произвольной функции
6 в произвольном диапазоне на текстовом экране произвольных размеров
7 с произвольным количеством точек ломаной
8 '''
9
10 from math import *
11 import sys
12
13 import pygame
14 pygame.init()
15
16 def definput(prompt, *default):
17 '''Вводит строку. Если она непустая, возвращает eval(строка).
18 Если ввод пуст, а в default -- ровно одна строка, возвращает эту строку.
19 Иначе возвращает default'''
20 print "%s %s:"%(prompt, default),
21 s = sys.stdin.readline().strip()
22 if s:
23 if len(default)==1 and type(default[0]) == str:
24 return s
25 else:
26 return eval(s)
27 if len(default)==1:
28 return default[0]
29 else:
30 return default
31
32 def scale(x, X0, X1, Z0, Z1):
33 'Преобразует координату x в диапазоне [X0, X1] в координату z в диапазоне [Z0, Z1]'
34 return Z0+(Z1-Z0)*(x-X0)/float(X1-X0)
35
36 def round(x):
37 'Округлить x до ближайшего целого'
38 return int(floor(x+0.5))
39
40 def sign(x): return x > 0 and 1 or x < 0 and -1 or 0
41
42 def fun(x, eq):
43 'Вычисляет python-выражение eq с параметром x'
44 return eval(eq)
45
46 def grafun(X0, X1, count, formulae):
47 'Список длиной count вида [(x, formulae(x)),..], х из диапазона [X0, X1]'
48 ret=[]
49 for i in range(count):
50 x=scale(i, 0, count-1, X0, X1)
51 y=fun(x, formulae)
52 ret.append((x,y))
53 return ret
54
55 def dot(scr, x, y, char="*"):
56 'Поставить точку (по умолчанию "*") на виртуальный экран scr'
57 scr.fill(char,((x,y),(1,1)))
58
59 def rough(X,Y,W,H,x,y,d):
60 '''Определяет, насколько вектор (W,H) параллелен вектору (x+d[0],y+d[1])-(X,Y)'''
61 return fabs(H*(X-(x+d[0]))-W*(Y-(y+d[1])))
62
63 def line(scr, M1, M2, char="*"):
64 '''Нарисовать отрезок от точки M1 до M2 на экране scr'''
65 x1,y1,x2,y2 = (int(i) for i in M1+M2)
66 x,y,w,h = x1,y1,x2-x1,y2-y1
67 d = ((sign(w),sign(h)), fabs(w)>fabs(h) and (sign(w), 0) or (0,sign(h)))
68 #dot(scr,x,y,char)
69 while x != x2 or y != y2:
70 i = rough(x2, y2, w, h, x, y, d[0]) > rough(x2, y2, w, h, x, y, d[1]) and 1 or 0
71 x,y = x + d[i][0], y + d[i][1]
72 dot(scr,x,y,char)
73
74 fml = definput("Функция в виде формулы от x", "sin(x)")
75 X0, X1 = definput("Начало и конец диапазона", -4., 4.)
76 W, H = definput("Ширина и высота экрана", 800, 600)
77 N = definput("Количество точек ломаной",40)
78 X0, X1 = float(X0), float(X1)
79 print fml, X0, X1, W, H, N
80 pen=(10,100,200)
81 screen=pygame.display.set_mode((W,H))
82
83 # Построим график
84 gr=grafun(X0, X1, N, fml)
85 # Найдём минимум и максимум функции в этих точках
86 Y0, Y1 = min([e[1] for e in gr]), max([e[1] for e in gr])
87 # нарисуем график
88 for i in range(len(gr)-1):
89 line(screen, (round(scale(gr[i][0], X0, X1, 0, W-1)),
90 round(scale(gr[i][1], Y0, Y1, 0, H-1))),
91 (round(scale(gr[i+1][0],X0, X1, 0, W-1)),
92 round(scale(gr[i+1][1],Y0, Y1, 0, H-1))),
93 pen)
94 # выведем получившееся
95 pygame.display.flip()
96 while True:
97 pass
Прикреплённые файлы
Для ссылки на прикреплённый файл в тексте страницы напишите attachment:имяфайла, как показано ниже в списке файлов. Не используйте URL из ссылки «[получить]», так как он чисто внутренний и может измениться.- [получить | показать] (2011-09-26 11:35:27, 1.6 KB) [[attachment:Oval.seg]]
- [получить | показать] (2011-09-26 11:35:27, 2.4 KB) [[attachment:PyGameState_Editor.dia]]
- [получить | показать] (2011-09-26 11:35:27, 2.8 KB) [[attachment:PyGameState_Ellipse.dia]]
- [получить | показать] (2011-09-26 11:35:27, 2.8 KB) [[attachment:PyGameState_Figure.dia]]
- [получить | показать] (2011-09-26 11:35:27, 1.5 KB) [[attachment:PyGameState_Input.dia]]
- [получить | показать] (2011-09-26 11:35:27, 0.4 KB) [[attachment:grap_0.py]]
- [получить | показать] (2011-09-26 11:35:27, 1.4 KB) [[attachment:grap_1-1.py]]
- [получить | показать] (2011-09-26 11:35:27, 1.1 KB) [[attachment:grap_1.py]]
- [получить | показать] (2011-09-26 11:35:27, 1.8 KB) [[attachment:grap_2.py]]
- [получить | показать] (2011-09-26 11:35:27, 2.4 KB) [[attachment:grap_3.py]]
- [получить | показать] (2011-09-26 11:35:27, 2.6 KB) [[attachment:grap_4.py]]
- [получить | показать] (2011-09-26 11:35:27, 2.0 KB) [[attachment:grap_5-0.py]]
- [получить | показать] (2011-09-26 11:35:27, 4.8 KB) [[attachment:grap_5-1.py]]
- [получить | показать] (2011-09-26 11:35:27, 3.6 KB) [[attachment:grap_5.py]]
- [получить | показать] (2011-09-26 11:35:27, 3.5 KB) [[attachment:grap_6-0.py]]
- [получить | показать] (2011-09-26 11:35:27, 4.7 KB) [[attachment:grap_6.py]]
- [получить | показать] (2011-09-26 11:35:27, 9.7 KB) [[attachment:grap_7.py]]
- [получить | показать] (2011-09-26 11:35:27, 0.8 KB) [[attachment:pygame_0.py]]
- [получить | показать] (2011-09-26 11:35:27, 2.2 KB) [[attachment:pygame_1-1.py]]
- [получить | показать] (2011-09-26 11:35:27, 1.9 KB) [[attachment:pygame_1.py]]
- [получить | показать] (2011-09-26 11:35:27, 2.5 KB) [[attachment:pygame_2-0.py]]
- [получить | показать] (2011-09-26 11:35:27, 1.3 KB) [[attachment:pygame_2-1-0.py]]
- [получить | показать] (2011-09-26 11:35:27, 5.6 KB) [[attachment:pygame_2-1.py]]
Вам нельзя прикреплять файлы к этой странице.