OUTPUT BUFFER:
# convolution.tcl # # An example of the OpenGL red book modified to work with Tcl3D. # The original C sources are Copyright (c) 1993-2003, Silicon Graphics, Inc. # The Tcl3D sources are Copyright (c) 2005, Paul Obermeier. # See file LICENSE for complete license information. # # Use various 2D convolutions filters to find edges in an image. package require tcl3d 0.3.3 set horizontal [tcl3dVectorFromArgs GLfloat \ 0 -1 0 \ 0 1 0 \ 0 0 0 \ ] set vertical [tcl3dVectorFromArgs GLfloat \ 0 0 0 \ -1 1 0 \ 0 0 0 \ ] set laplacian [tcl3dVectorFromArgs GLfloat \ -0.125 -0.125 -0.125 \ -0.125 1.0 -0.125 \ -0.125 -0.125 -0.125 \ ] # Font to be used in the Tk listbox. set listFont {-family {Courier} -size 10} # Show errors occuring in the Togl callbacks. proc bgerror { msg } { tk_messageBox -icon error -type ok -message "Error: $msg\n\n$::errorInfo" exit } # Print info message into widget a the bottom of the window. proc PrintInfo { msg } { if { [winfo exists .fr.info] } { .fr.info configure -text $msg } } proc CreateCallback { toglwin } { glPixelStorei GL_UNPACK_ALIGNMENT 1 glClearColor 0.0 0.0 0.0 0.0 glConvolutionFilter2D GL_CONVOLUTION_2D GL_LUMINANCE \ 3 3 GL_LUMINANCE GL_FLOAT $::horizontal glEnable GL_CONVOLUTION_2D } proc DisplayCallback { toglwin } { glClear GL_COLOR_BUFFER_BIT # Viewport command is not really needed, but has been inserted for # Mac OSX. Presentation framework (Tk) does not send a reshape event, # when switching from one demo to another. glViewport 0 0 [$toglwin width] [$toglwin height] glRasterPos2i 1 1 glDrawPixels $::width $::height GL_RGB GL_UNSIGNED_BYTE $::pixels glFlush } proc ReshapeCallback { toglwin { w -1 } { h -1 } } { set w [$toglwin width] set h [$toglwin height] glViewport 0 0 $w $h glMatrixMode GL_PROJECTION glLoadIdentity glOrtho 0 $::width 0 $::height -1.0 1.0 glMatrixMode GL_MODELVIEW } proc UpdateMsg { msgStr } { .fr.usage configure -state normal .fr.usage delete end .fr.usage insert end $msgStr .fr.usage configure -state disabled } proc convFilter { toglwin filter msg } { UpdateMsg $msg glConvolutionFilter2D GL_CONVOLUTION_2D GL_LUMINANCE 3 3 \ GL_LUMINANCE GL_FLOAT $filter $toglwin postredisplay } set widthVec [tcl3dVector GLsizei 1] set heightVec [tcl3dVector GLsizei 1] set imgName [file join [file dirname [info script]] "Data" "leeds.bin"] set pixels [tcl3dReadRedBookImage [tcl3dGetExtFile $imgName] $widthVec $heightVec] set width [$widthVec get 0] set height [$heightVec get 0] frame .fr pack .fr -expand 1 -fill both togl .fr.toglwin -width $width -height $height \ -double false -alpha true \ -createproc CreateCallback \ -reshapeproc ReshapeCallback \ -displayproc DisplayCallback listbox .fr.usage -font $::listFont -height 4 label .fr.info grid .fr.toglwin -row 0 -column 0 -sticky news grid .fr.usage -row 1 -column 0 -sticky news grid .fr.info -row 2 -column 0 -sticky news grid rowconfigure .fr 0 -weight 1 grid columnconfigure .fr 0 -weight 1 wm title . "Tcl3D demo: OpenGL Red Book example convolution" set msg {"Using the horizontal filter"} bind .