Demo bezsurf

Demo 10 of 68 in category RedBook

Previous demo: poThumbs/bezmesh.jpgbezmesh
Next demo: poThumbs/blendeqn.jpgblendeqn
bezsurf.jpg
# bezsurf.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-2022, Paul Obermeier.
# See file LICENSE for complete license information.
#
# This program renders a wireframe Bezier surface,
# using two-dimensional evaluators.

package require tcl3d

set ctrlpoints {
   {{-1.5 -1.5 4.0} {-0.5 -1.5 2.0} 
    {0.5 -1.5 -1.0} {1.5 -1.5 2.0}} 
   {{-1.5 -0.5 1.0} {-0.5 -0.5 3.0} 
    {0.5 -0.5 0.0} {1.5 -0.5 -1.0}} 
   {{-1.5 0.5 4.0} {-0.5 0.5 0.0} 
    {0.5 0.5 3.0} {1.5 0.5 4.0}} 
   {{-1.5 1.5 -2.0} {-0.5 1.5 -2.0} 
    {0.5 1.5 0.0} {1.5 1.5 -1.0}}
}

# 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 } {
   glClearColor 0.0 0.0 0.0 0.0
   glMap2f GL_MAP2_VERTEX_3 0 1 3 4 \
           0 1 12 4 [join [join $::ctrlpoints]]
   glEnable GL_MAP2_VERTEX_3
   glMapGrid2f 20 0.0 1.0 20 0.0 1.0
   glEnable GL_DEPTH_TEST
   glShadeModel GL_FLAT
}

proc DisplayCallback { toglwin } {
    glClear [expr $::GL_COLOR_BUFFER_BIT | $::GL_DEPTH_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]

    glColor3f 1.0 1.0 1.0
    glPushMatrix
    glRotatef 85.0 1.0 1.0 1.0
    for { set j 0 } { $j <= 8 } { incr j } {
        glBegin GL_LINE_STRIP
        for { set i 0 } { $i <= 30 } { incr i } {
            glEvalCoord2f [expr double($i)/30.0] [expr double($j)/8.0]
        }
        glEnd
        glBegin GL_LINE_STRIP
        for { set i 0 } { $i <= 30 } { incr i } {
            glEvalCoord2f [expr double($j)/8.0] [expr double($i)/30.0]
        }
        glEnd
    }
    glPopMatrix
    glFlush
    $toglwin swapbuffers
}

proc ReshapeCallback { toglwin { w -1 } { h -1 } } {
    set w [$toglwin width]
    set h [$toglwin height]

    glViewport 0 0 $w $h
    glMatrixMode GL_PROJECTION
    glLoadIdentity
    if { $w <= $h } {
        glOrtho -4.0 4.0 \
                [expr -4.0*double($h)/double($w)] \
                [expr 4.0*double($h)/double($w)] \
                -4.0 4.0
    } else {
        glOrtho [expr -4.0*double($w)/double($h)] \
                [expr 4.0*double($w)/double($h)] \
                -4.0 4.0 -4.0 4.0
    }
    glMatrixMode GL_MODELVIEW
    glLoadIdentity
}

frame .fr
pack .fr -expand 1 -fill both
togl .fr.toglwin -width 500 -height 500 -double true -depth true \
                 -createcommand CreateCallback \
                 -reshapecommand ReshapeCallback \
                 -displaycommand DisplayCallback 
listbox .fr.usage -font $::listFont -height 1
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 bezsurf"

bind . <Key-Escape> "exit"

.fr.usage insert end "Key-Escape Exit"
.fr.usage configure -state disabled

PrintInfo [tcl3dOglGetInfoString]

Top of page