Repository URL to install this package:
Version:
7.26.0-0.2 ▾
|
# E H Y E D I T F R A M E . T C L
# BRL-CAD
#
# Copyright (c) 2002-2016 United States Government as represented by
# the U.S. Army Research Laboratory.
#
# This library is free software; you can redistribute it and/or
# modify it under the terms of the GNU Lesser General Public License
# version 2.1 as published by the Free Software Foundation.
#
# This library is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public
# License along with this file; see the file named COPYING for more
# information.
#
###
#
# Author(s):
# Bob Parker
#
# Description:
# The class for editing ehys within Archer.
#
##############################################################
::itcl::class EhyEditFrame {
inherit GeometryEditFrame
constructor {args} {}
destructor {}
public {
# Override what's in GeometryEditFrame
method initGeometry {gdata}
method updateGeometry {}
method checkpointGeometry {}
method revertGeometry {}
method createGeometry {obj}
method p {obj args}
}
protected {
common setH 1
common setA 2
common setB 3
common setC 4
variable mVx ""
variable mVy ""
variable mVz ""
variable mHx ""
variable mHy ""
variable mHz ""
variable mAx ""
variable mAy ""
variable mAz ""
variable mR_1 ""
variable mR_2 ""
variable mC ""
# Checkpoint values
variable checkpointed_name ""
variable cmVx ""
variable cmVy ""
variable cmVz ""
variable cmHx ""
variable cmHy ""
variable cmHz ""
variable cmAx ""
variable cmAy ""
variable cmAz ""
variable cmR_1 ""
variable cmR_2 ""
variable cmC ""
# Methods used by the constructor
# override methods in GeometryEditFrame
method buildUpperPanel
method buildLowerPanel
# Override what's in GeometryEditFrame
method updateGeometryIfMod {}
method initEditState {}
}
private {}
}
# ------------------------------------------------------------
# CONSTRUCTOR
# ------------------------------------------------------------
::itcl::body EhyEditFrame::constructor {args} {
eval itk_initialize $args
}
# ------------------------------------------------------------
# OPTIONS
# ------------------------------------------------------------
# ------------------------------------------------------------
# PUBLIC METHODS
# ------------------------------------------------------------
## - initGeometry
#
# Initialize the variables containing the object's specification.
#
::itcl::body EhyEditFrame::initGeometry {gdata} {
set _V [bu_get_value_by_keyword V $gdata]
set mVx [lindex $_V 0]
set mVy [lindex $_V 1]
set mVz [lindex $_V 2]
set _H [bu_get_value_by_keyword H $gdata]
set mHx [lindex $_H 0]
set mHy [lindex $_H 1]
set mHz [lindex $_H 2]
set _A [bu_get_value_by_keyword A $gdata]
set mAx [lindex $_A 0]
set mAy [lindex $_A 1]
set mAz [lindex $_A 2]
set mR_1 [bu_get_value_by_keyword r_1 $gdata]
set mR_2 [bu_get_value_by_keyword r_2 $gdata]
set mC [bu_get_value_by_keyword c $gdata]
GeometryEditFrame::initGeometry $gdata
set curr_name $itk_option(-geometryObject)
if {$cmC == "" || "$checkpointed_name" != "$curr_name"} {checkpointGeometry}
}
::itcl::body EhyEditFrame::updateGeometry {} {
if {$itk_option(-mged) == "" ||
$itk_option(-geometryObject) == ""} {
return
}
$itk_option(-mged) adjust $itk_option(-geometryObject) \
V [list $mVx $mVy $mVz] \
H [list $mHx $mHy $mHz] \
A [list $mAx $mAy $mAz] \
r_1 $mR_1 \
r_2 $mR_2 \
c $mC
GeometryEditFrame::updateGeometry
}
::itcl::body EhyEditFrame::checkpointGeometry {} {
set checkpointed_name $itk_option(-geometryObject)
set cmVx $mVx
set cmVy $mVy
set cmVz $mVz
set cmHx $mHx
set cmHy $mHy
set cmHz $mHz
set cmAx $mAx
set cmAy $mAy
set cmAz $mAz
set cmR_1 $mR_1
set cmR_2 $mR_2
set cmC $mC
}
::itcl::body EhyEditFrame::revertGeometry {} {
set mVx $cmVx
set mVy $cmVy
set mVz $cmVz
set mHx $cmHx
set mHy $cmHy
set mHz $cmHz
set mAx $cmAx
set mAy $cmAy
set mAz $cmAz
set mR_1 $cmR_1
set mR_2 $cmR_2
set mC $cmC
updateGeometry
}
::itcl::body EhyEditFrame::createGeometry {obj} {
if {![GeometryEditFrame::createGeometry $obj]} {
return
}
$itk_option(-mged) put $obj ehy \
V [list $mCenterX $mCenterY $mCenterZ] \
H [list 0 0 $mDelta] \
A {1 0 0} \
r_1 $mDelta \
r_2 $mDelta \
c $mDelta
}
::itcl::body EhyEditFrame::p {obj args} {
if {[llength $args] != 1 || ![string is double $args]} {
return "Usage: p sf"
}
switch -- $mEditMode \
$setH {
$::ArcherCore::application p_pscale $obj h $args
} \
$setA {
$::ArcherCore::application p_pscale $obj a $args
} \
$setB {
$::ArcherCore::application p_pscale $obj b $args
} \
$setC {
$::ArcherCore::application p_pscale $obj c $args
}
return ""
}
# ------------------------------------------------------------
# PROTECTED METHODS
# ------------------------------------------------------------
::itcl::body EhyEditFrame::buildUpperPanel {} {
set parent [$this childsite]
itk_component add ehyType {
::ttk::label $parent.ehytype \
-text "Ehy:" \
-anchor e
} {}
itk_component add ehyName {
::ttk::label $parent.ehyname \
-textvariable [::itcl::scope itk_option(-geometryObject)] \
-anchor w
} {}
# Create header labels
itk_component add ehyXL {
::ttk::label $parent.ehyXL \
-text "X"
} {}
itk_component add ehyYL {
::ttk::label $parent.ehyYL \
-text "Y"
} {}
itk_component add ehyZL {
::ttk::label $parent.ehyZL \
-text "Z"
} {}
# create widgets for vertices
itk_component add ehyVL {
::ttk::label $parent.ehyVL \
-text "V:" \
-anchor e
} {}
itk_component add ehyVxE {
::ttk::entry $parent.ehyVxE \
-textvariable [::itcl::scope mVx] \
-validate key \
-validatecommand {::cadwidgets::Ged::validateDouble %P}
} {}
itk_component add ehyVyE {
::ttk::entry $parent.ehyVyE \
-textvariable [::itcl::scope mVy] \
-validate key \
-validatecommand {::cadwidgets::Ged::validateDouble %P}
} {}
itk_component add ehyVzE {
::ttk::entry $parent.ehyVzE \
-textvariable [::itcl::scope mVz] \
-validate key \
-validatecommand {::cadwidgets::Ged::validateDouble %P}
} {}
itk_component add ehyVUnitsL {
::ttk::label $parent.ehyVUnitsL \
-textvariable [::itcl::scope itk_option(-units)] \
-anchor e
} {}
itk_component add ehyHL {
::ttk::label $parent.ehyHL \
-text "H:" \
-anchor e
} {}
itk_component add ehyHxE {
::ttk::entry $parent.ehyHxE \
-textvariable [::itcl::scope mHx] \
-state disabled \
-validate key \
-validatecommand {::cadwidgets::Ged::validateDouble %P}
} {}
itk_component add ehyHyE {
::ttk::entry $parent.ehyHyE \
-textvariable [::itcl::scope mHy] \
-state disabled \
-validate key \
-validatecommand {::cadwidgets::Ged::validateDouble %P}
} {}
itk_component add ehyHzE {
::ttk::entry $parent.ehyHzE \
-textvariable [::itcl::scope mHz] \
-state disabled \
-validate key \
-validatecommand {::cadwidgets::Ged::validateDouble %P}
} {}
itk_component add ehyHUnitsL {
::ttk::label $parent.ehyHUnitsL \
-textvariable [::itcl::scope itk_option(-units)] \
-anchor e
} {}
itk_component add ehyAL {
::ttk::label $parent.ehyAL \
-text "A:" \
-anchor e
} {}
itk_component add ehyAxE {
::ttk::entry $parent.ehyAxE \
-textvariable [::itcl::scope mAx] \
-state disabled \
-validate key \
-validatecommand {::cadwidgets::Ged::validateDouble %P}
} {}
itk_component add ehyAyE {
::ttk::entry $parent.ehyAyE \
-textvariable [::itcl::scope mAy] \
-state disabled \
-validate key \
-validatecommand {::cadwidgets::Ged::validateDouble %P}
} {}
itk_component add ehyAzE {
::ttk::entry $parent.ehyAzE \
-textvariable [::itcl::scope mAz] \
-state disabled \
-validate key \
-validatecommand {::cadwidgets::Ged::validateDouble %P}
} {}
itk_component add ehyAUnitsL {
::ttk::label $parent.ehyAUnitsL \
-anchor e
} {}
itk_component add ehyR_1L {
::ttk::label $parent.ehyR_1L \
-text "r_1:" \
-anchor e
} {}
itk_component add ehyR_1E {
::ttk::entry $parent.ehyR_1E \
-textvariable [::itcl::scope mR_1] \
-validate key \
-validatecommand {::cadwidgets::Ged::validateDouble %P}
} {}
itk_component add ehyR_1UnitsL {
::ttk::label $parent.ehyR_1UnitsL \
-textvariable [::itcl::scope itk_option(-units)] \
-anchor e
} {}
itk_component add ehyR_2L {
::ttk::label $parent.ehyR_2L \
-text "r_2:" \
-anchor e
} {}
itk_component add ehyR_2E {
::ttk::entry $parent.ehyR_2E \
-textvariable [::itcl::scope mR_2] \
-validate key \
-validatecommand {::cadwidgets::Ged::validateDouble %P}
} {}
itk_component add ehyR_2UnitsL {
::ttk::label $parent.ehyR_2UnitsL \
-textvariable [::itcl::scope itk_option(-units)] \
-anchor e
} {}
itk_component add ehyCL {
::ttk::label $parent.ehyCL \
-text "c:" \
-anchor e
} {}
itk_component add ehyCE {
::ttk::entry $parent.ehyCE \
-textvariable [::itcl::scope mC] \
-validate key \
-validatecommand {::cadwidgets::Ged::validateDouble %P}
} {}
itk_component add ehyCUnitsL {
::ttk::label $parent.ehyCUnitsL \
-anchor e
} {}
itk_component add checkpointButton {
::ttk::button $parent.checkpointButton \
-text {CheckPoint} \
-command "[::itcl::code $this checkpointGeometry]"
} {}
itk_component add revertButton {
::ttk::button $parent.revertButton \
-text {Revert} \
-command "[::itcl::code $this revertGeometry]"
} {}
set row 0
grid $itk_component(ehyType) \
-row $row \
-column 0 \
-sticky nsew
grid $itk_component(ehyName) \
-row $row \
-column 1 \
-columnspan 3 \
-sticky nsew
incr row
grid x $itk_component(ehyXL) \
$itk_component(ehyYL) \
$itk_component(ehyZL)
incr row
grid $itk_component(ehyVL) \
$itk_component(ehyVxE) \
$itk_component(ehyVyE) \
$itk_component(ehyVzE) \
$itk_component(ehyVUnitsL) \
-row $row \
-sticky nsew
incr row
grid $itk_component(ehyHL) \
$itk_component(ehyHxE) \
$itk_component(ehyHyE) \
$itk_component(ehyHzE) \
$itk_component(ehyHUnitsL) \
-row $row \
-sticky nsew
incr row
grid $itk_component(ehyAL) \
$itk_component(ehyAxE) \
$itk_component(ehyAyE) \
$itk_component(ehyAzE) \
$itk_component(ehyAUnitsL) \
-row $row \
-sticky nsew
incr row
grid $itk_component(ehyR_1L) $itk_component(ehyR_1E) \
-row $row \
-sticky nsew
grid $itk_component(ehyR_1UnitsL) \
-row $row \
-column 4 \
-sticky nsew
incr row
grid $itk_component(ehyR_2L) $itk_component(ehyR_2E) \
-row $row \
-sticky nsew
grid $itk_component(ehyR_2UnitsL) \
-row $row \
-column 4 \
-sticky nsew
incr row
grid $itk_component(ehyCL) $itk_component(ehyCE) \
-row $row \
-sticky nsew
grid $itk_component(ehyCUnitsL) \
-row $row \
-column 4 \
-sticky nsew
incr row
set col 0
grid $itk_component(checkpointButton) \
-row $row \
-column $col \
-columnspan 2 \
-sticky nsew
incr col
incr col
grid $itk_component(revertButton) \
-row $row \
-column $col \
-columnspan 2 \
-sticky nsew
grid columnconfigure $parent 1 -weight 1
grid columnconfigure $parent 2 -weight 1
grid columnconfigure $parent 3 -weight 1
pack $parent -expand yes -fill x -anchor n
# Set up bindings
bind $itk_component(ehyVxE) <Return> [::itcl::code $this updateGeometryIfMod]
bind $itk_component(ehyVyE) <Return> [::itcl::code $this updateGeometryIfMod]
bind $itk_component(ehyVzE) <Return> [::itcl::code $this updateGeometryIfMod]
bind $itk_component(ehyHxE) <Return> [::itcl::code $this updateGeometryIfMod]
bind $itk_component(ehyHyE) <Return> [::itcl::code $this updateGeometryIfMod]
bind $itk_component(ehyHzE) <Return> [::itcl::code $this updateGeometryIfMod]
bind $itk_component(ehyAxE) <Return> [::itcl::code $this updateGeometryIfMod]
bind $itk_component(ehyAyE) <Return> [::itcl::code $this updateGeometryIfMod]
bind $itk_component(ehyAzE) <Return> [::itcl::code $this updateGeometryIfMod]
bind $itk_component(ehyR_1E) <Return> [::itcl::code $this updateGeometryIfMod]
bind $itk_component(ehyR_2E) <Return> [::itcl::code $this updateGeometryIfMod]
bind $itk_component(ehyCE) <Return> [::itcl::code $this updateGeometryIfMod]
}
::itcl::body EhyEditFrame::buildLowerPanel {} {
set parent [$this childsite lower]
set row 0
foreach attribute {H A B C} {
itk_component add set$attribute {
::ttk::radiobutton $parent.set_$attribute \
-variable [::itcl::scope mEditMode] \
-value [subst $[subst set$attribute]] \
-text "Set $attribute" \
-command [::itcl::code $this initEditState]
} {}
grid $itk_component(set$attribute) -row $row -column 0 -sticky nsew
incr row
}
}
::itcl::body EhyEditFrame::updateGeometryIfMod {} {
if {$itk_option(-mged) == "" ||
$itk_option(-geometryObject) == ""} {
return
}
set gdata [$itk_option(-mged) get $itk_option(-geometryObject)]
set gdata [lrange $gdata 1 end]
set _V [bu_get_value_by_keyword V $gdata]
set _Vx [lindex $_V 0]
set _Vy [lindex $_V 1]
set _Vz [lindex $_V 2]
set _H [bu_get_value_by_keyword H $gdata]
set _Hx [lindex $_H 0]
set _Hy [lindex $_H 1]
set _Hz [lindex $_H 2]
set _A [bu_get_value_by_keyword A $gdata]
set _Ax [lindex $_A 0]
set _Ay [lindex $_A 1]
set _Az [lindex $_A 2]
set _R_1 [bu_get_value_by_keyword r_1 $gdata]
set _R_2 [bu_get_value_by_keyword r_2 $gdata]
set _C [bu_get_value_by_keyword c $gdata]
if {$mVx == "" ||
$mVx == "-" ||
$mVy == "" ||
$mVy == "-" ||
$mVz == "" ||
$mVz == "-" ||
$mHx == "" ||
$mHx == "-" ||
$mHy == "" ||
$mHy == "-" ||
$mHz == "" ||
$mHz == "-" ||
$mAx == "" ||
$mAx == "-" ||
$mAy == "" ||
$mAy == "-" ||
$mAz == "" ||
$mAz == "-" ||
$mR_1 == "" ||
$mR_1 == "-" ||
$mR_2 == "" ||
$mR_2 == "-" ||
$mC == "" ||
$mC == "-"} {
# Not valid
return
}
if {$_Vx != $mVx ||
$_Vy != $mVy ||
$_Vz != $mVz ||
$_Hx != $mHx ||
$_Hy != $mHy ||
$_Hz != $mHz ||
$_Ax != $mAx ||
$_Ay != $mAy ||
$_Az != $mAz ||
$_R_1 != $mR_1 ||
$_R_2 != $mR_2 ||
$_C != $mC} {
updateGeometry
}
}
::itcl::body EhyEditFrame::initEditState {} {
set mEditCommand pscale
set mEditPCommand [::itcl::code $this p]
configure -valueUnits "mm"
switch -- $mEditMode \
$setH {
set mEditParam1 h
set mEditClass $EDIT_CLASS_SCALE
} \
$setA {
set mEditParam1 a
set mEditClass $EDIT_CLASS_SCALE
} \
$setB {
set mEditParam1 b
set mEditClass $EDIT_CLASS_SCALE
} \
$setC {
set mEditParam1 c
set mEditClass $EDIT_CLASS_SCALE
} \
default {
set mEditCommand ""
set mEditPCommand ""
set mEditParam1 ""
}
GeometryEditFrame::initEditState
}
# Local Variables:
# mode: Tcl
# tab-width: 8
# c-basic-offset: 4
# tcl-indent-level: 4
# indent-tabs-mode: t
# End:
# ex: shiftwidth=4 tabstop=8