-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathbresenham_line_less-1.py
91 lines (65 loc) · 2.23 KB
/
bresenham_line_less-1.py
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
86
87
88
89
90
91
from __future__ import division
from __future__ import print_function
import glfw
from OpenGL.GL import *
from OpenGL.GLU import *
import numpy as np
from math import floor
def key_callback(window, key, scancode, action, mode):
if key == glfw.KEY_ESCAPE and action == glfw.PRESS:
print("closed window for pressing Escape key")
glfw.set_window_should_close(window, True)
def reshape_callback(window, width, height):
glViewport(0,0,width, height)
def setpixel(x,y,color):
glColor3fv(color)
glBegin(GL_POINTS)
glVertex2f(x,y)
glEnd()
def BresenhamLine(x1,y1,x2,y2, colour):
x=x1
y=y1
dx=(x2-x1)
dy=-(y2-y1)
dt= 2*(dy-dx)
ds=2*dy
d=2*dy - dx #d=d0 initially
setpixel((x), (y), [0,0,0])
while x<x2:
x=x+1
if d <0:
d=d+ds
else:
y=y-1
d=d+dt
setpixel((x), (y), colour)
def main():
if not glfw.init():
raise Exception("glfw nt initialized")
window=glfw.create_window(640,480, "DDA Line Drawing",None,None)
if not window:
glfw.terminate()
raise Exception("glfw window not created")
w,h = glfw.get_framebuffer_size(window)
print("width: {}, height:{}".format(w,h))
glfw.set_window_pos(window, 400,200)
glfw.make_context_current(window)
glfw.set_key_callback(window, key_callback)
glfw.set_window_size_callback(window, reshape_callback)
gluOrtho2D(-200.0, 200.0,-200.0,200.0)
setpixel(0,0,[1,0,1])
while not glfw.window_should_close(window):
glClear(GL_COLOR_BUFFER_BIT)
#glClearColor(0.0,0.76,0.56,1.0)
glClearColor(1,1,1,1.0)
BresenhamLine(-150,-150,150,150, [1,0,1])#L2 pink
BresenhamLine(-150,-50,150,50,[1,1,0])#L1 yellow
BresenhamLine(-50,-150,50,150, [1,0,0]) #L3 red
BresenhamLine(-50,150,50,-150, [0,1,0])#L4 green
BresenhamLine(-150,150,150,-150,[0,0,1])#L5 blue correct
BresenhamLine(-150,50,150,-50,[0,1,1]) #L6 cyan/ sky blue correct
glfw.swap_buffers(window)
glfw.poll_events()
glfw.terminate()
if __name__ =="__main__":
main()