OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [insight/] [itcl/] [iwidgets3.0.0/] [generic/] [labeledframe.itk] - Rev 1765

Compare with Previous | Blame | View Log

#
# Labeledframe
# ----------------------------------------------------------------------
# Implements a hull frame with a grooved relief, a label, and a
# frame childsite.
#
# The frame childsite can be filled with any widget via a derived class
# or though the use of the childsite method.  This class was designed
# to be a general purpose base class for supporting the combination of
# a labeled frame and a childsite.  The options include the ability to
# position the label at configurable locations within the grooved relief
# of the hull frame, and control the display of the label.
#
#  To following demonstrates the different values which the "-labelpos"
#  option may be set to and the resulting layout of the label when
#  one executes the following command with "-labeltext" set to "LABEL":
#
#  example:
#   labeledframe .w -labeltext LABEL -labelpos <ne,n,nw,se,s,sw,en,e,es,wn,s,ws>
#
#      ne          n         nw         se          s         sw
#
#   *LABEL****  **LABEL**  ****LABEL*  **********  ********* **********
#   *        *  *       *  *        *  *        *  *       * *        *  
#   *        *  *       *  *        *  *        *  *       * *        *  
#   *        *  *       *  *        *  *        *  *       * *        *
#   **********  *********  **********  *LABEL****  **LABEL** ****LABEL*
#
#      en          e         es         wn          s         ws
#
#   **********  *********  *********  *********  *********  **********
#   *        *  *        * *       *  *        * *       *  *        *
#   L        *  *        * *       *  *        L *       *  *        *
#   A        *  L        * *       *  *        A *       L  *        L
#   B        *  A        * L       *  *        B *       A  *        A
#   E        *  B        * A       *  *        E *       B  *        B
#   L        *  E        * B       *  *        L *       E  *        E
#   *        *  L        * E       *  *        * *       L  *        L
#   *        *  *        * L       *  *        * *       *  *        *
#   **********  ********** *********  ********** *********  **********
#
# ----------------------------------------------------------------------
#  AUTHOR: John A. Tucker               EMAIL: jatucker@spd.dsccc.com
#
# ======================================================================
#            Copyright (c) 1997 DSC Technologies Corporation
# ======================================================================
# Permission to use, copy, modify, distribute and license this software 
# and its documentation for any purpose, and without fee or written 
# agreement with DSC, is hereby granted, provided that the above copyright 
# notice appears in all copies and that both the copyright notice and 
# warranty disclaimer below appear in supporting documentation, and that 
# the names of DSC Technologies Corporation or DSC Communications 
# Corporation not be used in advertising or publicity pertaining to the 
# software without specific, written prior permission.
# 
# DSC DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING 
# ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, AND NON-
# INFRINGEMENT. THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, AND THE
# AUTHORS AND DISTRIBUTORS HAVE NO OBLIGATION TO PROVIDE MAINTENANCE, 
# SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS. IN NO EVENT SHALL 
# DSC BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR 
# ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, 
# WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTUOUS ACTION,
# ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS 
# SOFTWARE.
# ======================================================================

#
# Default resources.
#
option add *Labeledframe.labelMargin    10      widgetDefault
option add *Labeledframe.labelFont     \
      "-Adobe-Helvetica-Bold-R-Normal--*-120-*-*-*-*-*-*"  widgetDefault
option add *Labeledframe.labelPos       n       widgetDefault
option add *Labeledframe.labelBorderWidth    2      widgetDefault
option add *Labeledframe.labelRelief         groove widgetDefault


#
# Usual options.
#
itk::usual Labeledframe {
    keep -background -cursor -labelfont -foreground -labelrelief -labelborderwidth
}

class iwidgets::Labeledframe {

  inherit itk::Widget

  itk_option define -ipadx iPadX IPad 0
  itk_option define -ipady iPadY IPad 0

  itk_option define -labelmargin labelMargin LabelMargin 10
  itk_option define -labelpos labelPos LabelPos n
  itk_option define -labeltext labelText LabelText ""

  constructor {args} {}
  destructor {}

  #
  # Public methods
  #
  public method childsite {}
  public method clientHandlesConfigure {{yes 1}}

  #
  # Private methods
  #
  private {
    method smt {value} { _setMarginThickness $value }
    method _positionLabel {{when later}}
    method _collapseMargin {}
    method _setMarginThickness {value}

    proc _initTable {}

    variable _reposition ""  ;# non-null => _positionLabel pending
    variable dontUpdate 0

    common _LAYOUT_TABLE 
  }
}

#
# Provide a lowercased access method for the Labeledframe class.
# 
proc ::iwidgets::labeledframe {pathName args} {
    uplevel ::iwidgets::Labeledframe $pathName $args
}

# -----------------------------------------------------------------------------
#                        CONSTRUCTOR
# -----------------------------------------------------------------------------
body iwidgets::Labeledframe::constructor { args } {
  #
  #  Create a window with the same name as this object
  #

  itk_component add labelFrame {
    frame $itk_interior.lf \
          -relief groove \
          -class [namespace tail [info class]]
  } {
    keep -background -cursor 
    rename -relief -labelrelief labelRelief LabelRelief 
    rename -borderwidth -labelborderwidth labelBorderWidth LabelBorderWidth
    rename -highlightbackground -background background Background
    rename -highlightcolor -background background Background
  }

  #
  # Create the childsite frame window
  # _______
  # |_____|
  # |_|X|_|
  # |_____|
  #
  itk_component add childsite {
    frame $itk_component(labelFrame).childsite -highlightthickness 0 -bd 0
  } 

  #
  # Create the label to be positioned within the grooved relief
  # of the labelFrame frame.
  #
  itk_component add label {
    label $itk_component(labelFrame).label -highlightthickness 0 -bd 0
  } { 
    usual
    rename -bitmap -labelbitmap labelBitmap Bitmap
    rename -font -labelfont labelFont Font
    rename -image -labelimage labelImage Image
    #rename -text -labeltext labelText Text
    rename -textvariable -labelvariable labelVariable Variable
    ignore -highlightthickness -highlightcolor -text
  }

  grid $itk_component(childsite) -row 1 -column 1 -sticky nsew
  grid columnconfigure $itk_component(labelFrame) 1 -weight 1
  grid rowconfigure    $itk_component(labelFrame) 1 -weight 1

  lappend after_script [code $this _positionLabel]
  bind $itk_component(label) <Configure> +[code $this _positionLabel]

  pack $itk_component(labelFrame) -fill both -expand 1

  #
  # Initialize the class array of layout configuration options.  Since
  # this is a one time only thing.
  #
  _initTable

  eval itk_initialize $args

  # 
  # When idle, position the label.
  #
  _positionLabel
}

# -----------------------------------------------------------------------------
#                           DESTRUCTOR
# -----------------------------------------------------------------------------
body iwidgets::Labeledframe::destructor {} {
  debug "In Labeledframe destructor for $this, reposition is $_reposition"
  if {$_reposition != ""} {
    debug "Canceling reposition $_reposition for $this"
    after cancel $_reposition
    set _reposition DESTRUCTOR
  }
}

# -----------------------------------------------------------------------------
#                             OPTIONS
# -----------------------------------------------------------------------------

# ------------------------------------------------------------------
# OPTION: -ipadx
#
# Specifies the width of the horizontal gap from the border to the
# the child site.
# ------------------------------------------------------------------
configbody iwidgets::Labeledframe::ipadx {
  grid configure $itk_component(childsite) -padx $itk_option(-ipadx)
  _positionLabel
}

# ------------------------------------------------------------------
# OPTION: -ipady
#
# Specifies the width of the vertical gap from the border to the
# the child site.
# ------------------------------------------------------------------
configbody iwidgets::Labeledframe::ipady {
  grid configure $itk_component(childsite) -pady $itk_option(-ipady)
  _positionLabel
}

# -----------------------------------------------------------------------------
# OPTION: -labelmargin
#
# Set the margin of the most adjacent side of the label to the labelFrame
# relief.
# ----------------------------------------------------------------------------
configbody iwidgets::Labeledframe::labelmargin {
  _positionLabel
}

# -----------------------------------------------------------------------------
# OPTION: -labelpos
#
# Set the position of the label within the relief of the labelFrame frame
# widget.
# ----------------------------------------------------------------------------
configbody iwidgets::Labeledframe::labelpos {
  _positionLabel
}

# -----------------------------------------------------------------------------
# OPTION: -labelpos
#
# Set the position of the label within the relief of the labelFrame frame
# widget.
# ----------------------------------------------------------------------------
configbody iwidgets::Labeledframe::labeltext {
  $itk_component(label) configure -text $itk_option(-labeltext)
  _positionLabel
}

# -----------------------------------------------------------------------------
#                            PROCS
# -----------------------------------------------------------------------------

# -----------------------------------------------------------------------------
# PRIVATE PROC: _initTable
#
# Initializes the _LAYOUT_TABLE common variable of the Labeledframe
# class.  The initialization is performed in its own proc ( as opposed
# to in the class definition ) so that the initialization occurs only
# once.
#
# _LAYOUT_TABLE common array description:
#   Provides a table of the configuration option values
#   used to place the label widget within the grooved relief of the labelFrame
#   frame for each of the 12 possible "-labelpos" values.
#
#   Each of the 12 rows is layed out as follows:
#     {"-relx" "-rely" <rowconfigure|columnconfigure> <row/column number>}
# -----------------------------------------------------------------------------
body iwidgets::Labeledframe::_initTable {} {
  array set _LAYOUT_TABLE {
    nw-relx 0.0  nw-rely 0.0  nw-wrap 0 nw-conf rowconfigure    nw-num 0
    n-relx  0.5  n-rely  0.0  n-wrap  0 n-conf  rowconfigure    n-num  0
    ne-relx 1.0  ne-rely 0.0  ne-wrap 0 ne-conf rowconfigure    ne-num 0

    sw-relx 0.0  sw-rely 1.0  sw-wrap 0 sw-conf rowconfigure    sw-num 2
    s-relx  0.5  s-rely  1.0  s-wrap  0 s-conf  rowconfigure    s-num  2
    se-relx 1.0  se-rely 1.0  se-wrap 0 se-conf rowconfigure    se-num 2

    en-relx 1.0  en-rely 0.0  en-wrap 1 en-conf columnconfigure en-num 2
    e-relx  1.0  e-rely  0.5  e-wrap  1 e-conf  columnconfigure e-num  2
    es-relx 1.0  es-rely 1.0  es-wrap 1 es-conf columnconfigure es-num 2

    wn-relx 0.0  wn-rely 0.0  wn-wrap 1 wn-conf columnconfigure wn-num 0
    w-relx  0.0  w-rely  0.5  w-wrap  1 w-conf  columnconfigure w-num  0
    ws-relx 0.0  ws-rely 1.0  ws-wrap 1 ws-conf columnconfigure ws-num 0
    }

  #
  # Since this is a one time only thing, we'll redefine the proc to be empty
  # afterwards so it only happens once.
  #
  # NOTE: Be careful to use the "body" command, or the proc will get lost!
  #
  itcl::body ::iwidgets::Labeledframe::_initTable {} {}
}

# -----------------------------------------------------------------------------
#                            METHODS
# -----------------------------------------------------------------------------

# -----------------------------------------------------------------------------
# PUBLIC METHOD:: childsite
#
# -----------------------------------------------------------------------------
body iwidgets::Labeledframe::childsite {} {
  return $itk_component(childsite)
}

# -----------------------------------------------------------------------------
# PUBLIC METHOD:: clientHandlesConfigure
#
# -----------------------------------------------------------------------------
body iwidgets::Labeledframe::clientHandlesConfigure {{yes 1}} {
  if {$yes} {
    set dontUpdate 1
    bind $itk_component(label) <Configure> { }
    return [code $this _positionLabel now]
  } else { 
    bind $itk_component(label) <Configure> [code $this _positionLabel]
    set dontUpdate 0
  }
}
# -----------------------------------------------------------------------------
# PROTECTED METHOD: _positionLabel ?when?
#
# Places the label in the relief of the labelFrame.  If "when" is "now", the
# change is applied immediately.  If it is "later" or it is not
# specified, then the change is applied later, when the application
# is idle.
# -----------------------------------------------------------------------------
body iwidgets::Labeledframe::_positionLabel {{when later}} {

  if {$when == "later"} {
    if {$_reposition != ""} {
      after cancel $_reposition
    }
    set _reposition [after idle [code $this _positionLabel now]]
    return
  } 

  set pos $itk_option(-labelpos)

  #
  # If there is not an entry for the "relx" value associated with
  # the given "-labelpos" option value, then it invalid.
  #
  if { [catch {set relx $_LAYOUT_TABLE($pos-relx)}] } {
    error "bad labelpos option\"$itk_option(-labelpos)\": should be\
                  nw, n, ne, sw, s, se, en, e, es, wn, w, or ws"
  }

  if {!$dontUpdate} {
    update idletasks
    if {[string compare $_reposition DESTRUCTOR] == 0} {
      # OOPS...  We are in the process of being destroyed.  Get out of here...
      debug "Stuck in _postionLabel during destruction"
      return
    }
  }

  $itk_component(label) configure -wraplength $_LAYOUT_TABLE($pos-wrap)

  # If there is no text in the label, do not add it to the computation.

  if {$itk_option(-labeltext) == ""} {
      set minsize 0
      if {[place slaves $itk_component(labelFrame)] != ""} {
          place forget $itk_component(label)
      }
    _setMarginThickness 0
  } else {
    set labelWidth [winfo reqwidth $itk_component(label)]
    set labelHeight [winfo reqheight $itk_component(label)]
      set borderwidth $itk_option(-labelborderwidth)
      set margin $itk_option(-labelmargin)

      switch $pos {
        nw {
          set labelThickness $labelHeight
          set minsize [expr $labelThickness/2.0]
          set xPos [expr $minsize+$borderwidth+$margin]
          set yPos -$minsize
        }
        n {
          set labelThickness $labelHeight
          set minsize [expr $labelThickness/2.0]
          set xPos [expr -$labelWidth/2.0]
          set yPos -$minsize
        }
        ne  {
          set labelThickness $labelHeight
          set minsize [expr $labelThickness/2.0]
          set xPos [expr -($minsize+$borderwidth+$margin+$labelWidth)]
          set yPos -$minsize
        }

        sw  {
          set labelThickness $labelHeight
          set minsize [expr $labelThickness/2.0]
          set xPos [expr $minsize+$borderwidth+$margin]
          set yPos -$minsize
        }
        s {
          set labelThickness $labelHeight
          set minsize [expr $labelThickness/2.0]
          set xPos [expr -$labelWidth/2.0]
          set yPos [expr -$labelHeight/2.0]
        }
        se {
          set labelThickness $labelHeight
          set minsize [expr $labelThickness/2.0]
          set xPos [expr -($minsize+$borderwidth+$margin+$labelWidth)]
          set yPos [expr -$labelHeight/2.0]
        }

        wn {
          set labelThickness $labelWidth
          set minsize [expr $labelThickness/2.0]
          set xPos -$minsize
          set yPos [expr $minsize+$margin+$borderwidth]
        }
        w {
          set labelThickness $labelWidth
          set minsize [expr $labelThickness/2.0]
          set xPos -$minsize
          set yPos [expr -($labelHeight/2.0)]
        }
        ws {
          set labelThickness $labelWidth
          set minsize [expr $labelThickness/2.0]
          set xPos -$minsize
          set yPos [expr -($minsize+$borderwidth+$margin+$labelHeight)]
        }

        en {
          set labelThickness $labelWidth
          set minsize [expr $labelThickness/2.0]
          set xPos -$minsize
          set yPos [expr $minsize+$borderwidth+$margin]
        }
        e {
          set labelThickness $labelWidth
          set minsize [expr $labelThickness/2.0]
          set xPos -$minsize
          set yPos [expr -($labelHeight/2.0)]
        }
        es {
          set labelThickness $labelWidth
          set minsize [expr $labelThickness/2.0]
          set xPos -$minsize
          set yPos [expr -($minsize+$borderwidth+$margin+$labelHeight)]
        }
      }
      _setMarginThickness $minsize

      place $itk_component(label) \
        -relx $_LAYOUT_TABLE($pos-relx) -x $xPos \
        -rely $_LAYOUT_TABLE($pos-rely) -y $yPos \
        -anchor nw
  }

  set what $_LAYOUT_TABLE($pos-conf)
  set number $_LAYOUT_TABLE($pos-num)

  grid $what $itk_component(labelFrame) $number -minsize $minsize

  set _reposition ""
}

# -----------------------------------------------------------------------------
# PROTECTED METHOD: _collapseMargin
#
# Resets the "-minsize" of all rows and columns of the labelFrame's grid
# used to set the label margin to 0
# -----------------------------------------------------------------------------
body iwidgets::Labeledframe::_collapseMargin {} {
  grid columnconfigure $itk_component(labelFrame) 0 -minsize 0
  grid columnconfigure $itk_component(labelFrame) 2 -minsize 0
  grid rowconfigure $itk_component(labelFrame) 0 -minsize 0
  grid rowconfigure $itk_component(labelFrame) 2 -minsize 0
}

# -----------------------------------------------------------------------------
# PROTECTED METHOD: _setMarginThickness
#
# Set the margin thickness ( i.e. the hidden "-highlightthickness"
# of the labelFrame ) to the input value.
#
# -----------------------------------------------------------------------------
body iwidgets::Labeledframe::_setMarginThickness {value} {
  $itk_component(labelFrame) configure -highlightthickness $value
}


Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.