[4775] | 1 | # This program is under CECILL_B licence. See footer for details. |
---|
| 2 | |
---|
| 3 | |
---|
| 4 | |
---|
| 5 | |
---|
| 6 | # COMPARATOR CREATION |
---|
| 7 | |
---|
| 8 | proc comparator_create { args } { |
---|
| 9 | set mandatory_arguments { path_father address } |
---|
| 10 | |
---|
| 11 | # Initializes the widget |
---|
| 12 | initWidget |
---|
| 13 | |
---|
| 14 | set widgetInfo($address-status) 0 |
---|
| 15 | set widgetInfo($address-boxsize) 15 |
---|
| 16 | set widgetInfo($address-statustxt) "" |
---|
| 17 | set title [dTree_getAttribute $XMLtree $full_address_XML "title"] |
---|
| 18 | set widgetInfo($address-folder) [dTree_getAttribute $XMLtree $full_address_XML "folder"] |
---|
| 19 | ttk::labelframe $win -text "$title" |
---|
| 20 | eval $widgetInfo(packme-$win) |
---|
| 21 | |
---|
| 22 | |
---|
| 23 | #ttk::label $win.lb -text "$title" |
---|
| 24 | #grid $win.lb -column 0 -row 0 -sticky news |
---|
| 25 | |
---|
| 26 | |
---|
| 27 | #frame for picker |
---|
| 28 | ttk::frame $win.t |
---|
| 29 | |
---|
| 30 | |
---|
| 31 | |
---|
| 32 | # size of widget |
---|
| 33 | set size_v [expr 0.3*$widgetInfo(guiBigWidgetWidth)] |
---|
| 34 | set size_h [expr 0.3*$widgetInfo(guiBigWidgetWidth)] |
---|
| 35 | canvas $win.t.can -background [ThemeColor 1.0] -highlightthickness 1 -highlightbackground [ThemeColor 0.5] -yscrollcommand [list $win.t.sby set] -xscrollcommand [list $win.t.sbx set] -width $size_h -height $size_v |
---|
| 36 | ttk::scrollbar $win.t.sby -orient vertical -command [list $win.t.can yview] |
---|
| 37 | ttk::scrollbar $win.t.sbx -orient horizontal -command [list $win.t.can xview] |
---|
| 38 | grid $win.t.can -row 1 -column 0 -sticky news |
---|
| 39 | |
---|
| 40 | |
---|
| 41 | |
---|
| 42 | # frame for graphs |
---|
| 43 | ttk::frame $win.gr |
---|
| 44 | #pack $win.gr -side top -pady {0 5} |
---|
| 45 | |
---|
| 46 | set size_v [expr 0.3*$widgetInfo(guiBigWidgetWidth)] |
---|
| 47 | set size_h [expr 0.8*$widgetInfo(guiBigWidgetWidth)] |
---|
| 48 | canvas $win.gr.can -background [ThemeColor 1.0] -highlightthickness 1 -highlightbackground [ThemeColor 0.5] -yscrollcommand [list $win.gr.sby set] -xscrollcommand [list $win.gr.sbx set] -width $size_h -height $size_v |
---|
| 49 | ttk::scrollbar $win.gr.sby -orient vertical -command [list $win.gr.can yview] |
---|
| 50 | ttk::scrollbar $win.gr.sbx -orient horizontal -command [list $win.gr.can xview] |
---|
| 51 | |
---|
| 52 | ttk::frame $win.gr.c |
---|
| 53 | ttk::button $win.gr.c.zoomplus -image icon_magnifierplus -command [subst {grapher_zoom $win.gr.can 1.1}] |
---|
| 54 | ttk::button $win.gr.c.zoomminus -image icon_magnifierminus -command [subst {grapher_zoom $win.gr.can 0.9}] |
---|
| 55 | ttk::button $win.gr.c.dump -text "Dump" -command [subst {comparator_dump $win $address }] |
---|
| 56 | ttk::label $win.gr.c.statustxt -textvariable widgetInfo($address-statustxt) -compound left |
---|
| 57 | pack $win.gr.c.zoomplus -side left |
---|
| 58 | pack $win.gr.c.zoomminus -side left |
---|
| 59 | pack $win.gr.c.dump -side left |
---|
| 60 | pack $win.gr.c.statustxt -side left |
---|
| 61 | |
---|
| 62 | |
---|
| 63 | |
---|
| 64 | grid $win.gr.can -row 1 -column 0 -sticky news |
---|
| 65 | #grid $win.gr.sby -row 1 -column 1 -sticky ns |
---|
| 66 | #grid $win.gr.sbx -row 2 -column 0 -sticky ew |
---|
| 67 | grid $win.gr.c -row 3 -column 0 -sticky ew |
---|
| 68 | |
---|
| 69 | |
---|
| 70 | |
---|
| 71 | # frame for treeview |
---|
| 72 | ttk::frame $win.tv |
---|
| 73 | |
---|
| 74 | |
---|
| 75 | ttk::treeview $win.tv.tv -yscrollcommand [list $win.tv.sby set] -columns "lvalue rvalue" -height 8 |
---|
| 76 | $win.tv.tv column #0 -width [expr {int(0.3*$widgetInfo(guiBigWidgetWidth))}] |
---|
| 77 | $win.tv.tv column 0 -width [expr {int(0.4*$widgetInfo(guiBigWidgetWidth))}] |
---|
| 78 | $win.tv.tv column 1 -width [expr {int(0.4*$widgetInfo(guiBigWidgetWidth))}] |
---|
| 79 | |
---|
| 80 | |
---|
| 81 | #$win.tv.tv insert {} 0 -id "dataset" -text "." -open "true" |
---|
| 82 | |
---|
| 83 | ttk::scrollbar $win.tv.sby -orient vertical -command [list $win.tv.tv yview] |
---|
| 84 | |
---|
| 85 | |
---|
| 86 | |
---|
| 87 | |
---|
| 88 | grid $win.tv.tv -row 1 -column 0 -sticky news |
---|
| 89 | grid $win.tv.sby -row 1 -column 1 -sticky ns |
---|
| 90 | |
---|
| 91 | |
---|
| 92 | |
---|
| 93 | grid $win.t -column 0 -row 0 -sticky news |
---|
| 94 | grid $win.gr -column 1 -row 0 -sticky news |
---|
| 95 | grid $win.tv -column 0 -row 1 -sticky news -columnspan 2 |
---|
| 96 | |
---|
| 97 | |
---|
| 98 | |
---|
| 99 | #add the check/refresh procedure to the bindings of the variable |
---|
| 100 | append widgetInfo($address-refresh) [ subst { comparator_refresh $win $address}] |
---|
| 101 | append widgetInfo($address-check) [subst { comparator_check $win $address}] |
---|
| 102 | |
---|
| 103 | finishWidget |
---|
| 104 | |
---|
| 105 | #trick? |
---|
| 106 | #bind $win.t.can <ButtonPress-1> {+; focus %W} |
---|
| 107 | bind $win.t.can <Motion> [subst {comparator_showlocation $win $address}] |
---|
| 108 | # scroll |
---|
| 109 | bind $win.t.can <ButtonPress> [subst {$win.t.can scan mark %x %y}] |
---|
| 110 | bind $win.t.can <B1-Motion> [subst {$win.t.can scan dragto %x %y 1}] |
---|
| 111 | |
---|
| 112 | |
---|
| 113 | # clean the widget callBack on dstruction |
---|
| 114 | bind $win <Destroy> [ subst {widget_destroy $win $address}] |
---|
| 115 | |
---|
| 116 | return $win |
---|
| 117 | } |
---|
| 118 | |
---|
| 119 | proc comparator_refresh {win address} { |
---|
| 120 | global widgetInfo |
---|
| 121 | comparator_update $win $address |
---|
| 122 | } |
---|
| 123 | |
---|
| 124 | proc comparator_update {win address} { |
---|
| 125 | global widgetInfo |
---|
| 126 | |
---|
| 127 | $win.t.can delete all |
---|
| 128 | |
---|
| 129 | set list_runs $widgetInfo($address-requiredValue) |
---|
| 130 | |
---|
| 131 | # remove selected comparisons from the variable if this run is no more available |
---|
| 132 | set current_variable [split $widgetInfo($address-variable) ";"] |
---|
| 133 | foreach selectedpair $current_variable { |
---|
| 134 | set run1 [lindex [split $selectedpair "@"] 0] |
---|
| 135 | set run2 [lindex [split $selectedpair "@"] 1] |
---|
| 136 | if {[lsearch $list_runs $run1 ] == -1 } { |
---|
| 137 | set current_variable [lremove current_variable $selectedpair] |
---|
| 138 | } elseif {[lsearch $list_runs $run2 ]==-1} { |
---|
| 139 | set current_variable [lremove current_variable $selectedpair] |
---|
| 140 | } |
---|
| 141 | } |
---|
| 142 | |
---|
| 143 | set boxsize $widgetInfo($address-boxsize) |
---|
| 144 | |
---|
| 145 | #title up |
---|
| 146 | set col 0 |
---|
| 147 | foreach run $list_runs { |
---|
| 148 | set title_x [expr { $boxsize*(0.5+$col)}] |
---|
| 149 | set title_y [expr { $boxsize*(-0.0)}] |
---|
| 150 | set run_sim [lindex [split $run "#"] 0] |
---|
| 151 | set run_proj [lindex [split $run "#"] 1] |
---|
| 152 | set run_run [lindex [split $run "#"] 2] |
---|
| 153 | canvas_text_vector $win.t.can $title_x $title_y "$run_proj $run_run" sw 8 -45 [comparator_getcolor $run_sim] titleup |
---|
| 154 | incr col |
---|
| 155 | } |
---|
| 156 | #title left |
---|
| 157 | set col 0 |
---|
| 158 | foreach run $list_runs { |
---|
| 159 | set title_x [expr { $boxsize*(-0.2+$col)}] |
---|
| 160 | set title_y [expr { $boxsize*(0.2+$col)}] |
---|
| 161 | set run_sim [lindex [split $run "#"] 0] |
---|
| 162 | set run_proj [lindex [split $run "#"] 1] |
---|
| 163 | set run_run [lindex [split $run "#"] 2] |
---|
| 164 | canvas_text_vector $win.t.can $title_x $title_y "$run_proj $run_run" nw 8 0 [comparator_getcolor $run_sim] titleup |
---|
| 165 | incr col |
---|
| 166 | } |
---|
| 167 | |
---|
| 168 | set row 0 |
---|
| 169 | set col 0 |
---|
| 170 | foreach run1 $list_runs { |
---|
| 171 | foreach run2 $list_runs { |
---|
| 172 | set run1_sim [lindex [split $run1 "#"] 0] |
---|
| 173 | set run2_sim [lindex [split $run2 "#"] 0] |
---|
| 174 | set run1_proj [lindex [split $run1 "#"] 1] |
---|
| 175 | set run2_proj [lindex [split $run2 "#"] 1] |
---|
| 176 | set run1_run [lindex [split $run1 "#"] 2] |
---|
| 177 | set run2_run [lindex [split $run2 "#"] 2] |
---|
| 178 | if {$col >= $row} { |
---|
| 179 | if {$col == $row } { |
---|
| 180 | set shade 0.0 |
---|
| 181 | } elseif {$run1_sim == $run2_sim} { |
---|
| 182 | set shade 0.5 |
---|
| 183 | } else { |
---|
| 184 | set shade 0.75 |
---|
| 185 | } |
---|
| 186 | |
---|
| 187 | set couple "$run1@$run2" |
---|
| 188 | # ul_x-------------- |
---|
| 189 | # ul_y | |
---|
| 190 | # | | |
---|
| 191 | # | ul2_x---| | |
---|
| 192 | # | ul2_Y | | |
---|
| 193 | # | | | | |
---|
| 194 | # | | lr2_x | |
---|
| 195 | # | |------lr2_y | |
---|
| 196 | # | | |
---|
| 197 | # | | |
---|
| 198 | # | lr_x |
---|
| 199 | # |-------------lr_y |
---|
| 200 | set ul_x [expr {$col*$boxsize}] |
---|
| 201 | set ul_y [expr {$row*$boxsize}] |
---|
| 202 | |
---|
| 203 | set lr_x [expr {$ul_x+$boxsize}] |
---|
| 204 | set lr_y [expr {$ul_y+$boxsize}] |
---|
| 205 | |
---|
| 206 | set ul2_x [expr {($col+0.2)*$boxsize}] |
---|
| 207 | set ul2_y [expr {($row+0.2)*$boxsize}] |
---|
| 208 | |
---|
| 209 | set lr2_x [expr {$ul_x+0.8*$boxsize}] |
---|
| 210 | set lr2_y [expr {$ul_y+0.8*$boxsize}] |
---|
| 211 | |
---|
| 212 | $win.t.can create polygon $ul_x $ul_y $ul_x $lr_y $lr_x $lr_y $ul_x $ul_y -fill [shadeColor [comparator_getcolor $run1_sim] $shade] -tags "$couple" |
---|
| 213 | $win.t.can create polygon $ul_x $ul_y $lr_x $ul_y $lr_x $lr_y $ul_x $ul_y -fill [shadeColor [comparator_getcolor $run2_sim] $shade] -tags "$couple" |
---|
| 214 | $win.t.can create line $ul_x $ul_y $lr_x $ul_y $lr_x $lr_y $ul_x $lr_y $ul_x $ul_y -fill black |
---|
| 215 | |
---|
| 216 | if {[lsearch $current_variable $couple] != -1} { |
---|
| 217 | $win.t.can create oval $ul2_x $ul2_y $lr2_x $lr2_y -outline white -width 2 -tags "$couple" |
---|
| 218 | } |
---|
| 219 | $win.t.can bind $couple <ButtonPress> [subst {comparator_clickrun $win $address $couple}] |
---|
| 220 | } |
---|
| 221 | incr col |
---|
| 222 | } |
---|
| 223 | set col 0 |
---|
| 224 | incr row |
---|
| 225 | } |
---|
| 226 | |
---|
| 227 | set widgetInfo($address-status) 0 |
---|
| 228 | set widgetInfo($address-statustxt) "Comparisons data need to be dumped..." |
---|
| 229 | $win.gr.c.statustxt configure -image icon_question |
---|
| 230 | |
---|
| 231 | $win.t.can configure -scrollregion [ $win.t.can bbox all] |
---|
| 232 | |
---|
| 233 | smartpacker_update_visibility $win $address |
---|
| 234 | |
---|
| 235 | |
---|
| 236 | set widgetInfo($address-variable) [join $current_variable ";"] |
---|
| 237 | } |
---|
| 238 | |
---|
| 239 | proc comparator_clickrun {win address selectedpair} { |
---|
| 240 | global widgetInfo |
---|
| 241 | |
---|
| 242 | |
---|
| 243 | set current_variable [split $widgetInfo($address-variable) ";"] |
---|
| 244 | $win.gr.can delete all |
---|
| 245 | if {[lsearch $current_variable $selectedpair] != -1 } { |
---|
| 246 | # remove a comparison |
---|
| 247 | set current_variable [lremove current_variable $selectedpair] |
---|
| 248 | set file1 [ lindex [ split $selectedpair "@"] 0 ] |
---|
| 249 | set file2 [ lindex [ split $selectedpair "@"] 1 ] |
---|
| 250 | #debug "Removes $file1 $file2" |
---|
| 251 | |
---|
| 252 | #$win.tx.txt configure -state normal |
---|
| 253 | #$win.tx.txt delete 0.0 end |
---|
| 254 | #$win.tx.txt configure -state disabled |
---|
| 255 | |
---|
| 256 | |
---|
| 257 | } else { |
---|
| 258 | # add a comparison |
---|
| 259 | lappend current_variable $selectedpair |
---|
| 260 | set file1 [ lindex [ split $selectedpair "@"] 0 ] |
---|
| 261 | set file2 [ lindex [ split $selectedpair "@"] 1 ] |
---|
| 262 | grapher_create $win $address $win.gr.can $win.tv.tv [file join {*}$widgetInfo($address-folder)] "$file1" "$file2" 0 |
---|
| 263 | #debug "Add $file1 $file2" |
---|
| 264 | } |
---|
| 265 | |
---|
| 266 | set widgetInfo($address-variable) [join $current_variable ";"] |
---|
| 267 | |
---|
| 268 | comparator_update $win $address |
---|
| 269 | |
---|
| 270 | eval $widgetInfo($address-check) |
---|
| 271 | return |
---|
| 272 | } |
---|
| 273 | |
---|
| 274 | |
---|
| 275 | proc comparator_getcolor {sim} { |
---|
| 276 | set color "black" |
---|
| 277 | switch $sim { |
---|
| 278 | "Sim.1" { |
---|
| 279 | set color "black" |
---|
| 280 | } |
---|
| 281 | "Sim.2" { |
---|
| 282 | set color "red" |
---|
| 283 | } |
---|
| 284 | "Sim.3" { |
---|
| 285 | set color "blue" |
---|
| 286 | } |
---|
| 287 | "Sim.4" { |
---|
| 288 | set color "green4" |
---|
| 289 | } |
---|
| 290 | } |
---|
| 291 | return $color |
---|
| 292 | |
---|
| 293 | } |
---|
| 294 | |
---|
| 295 | proc comparator_dump {win address} { |
---|
| 296 | global widgetInfo |
---|
| 297 | set current_variable [split $widgetInfo($address-variable) ";"] |
---|
| 298 | |
---|
| 299 | #cleaning |
---|
| 300 | foreach filename [glob -nocomplain [file join {*}$widgetInfo($address-folder) *.gif] ] { |
---|
| 301 | file delete -force $filename |
---|
| 302 | } |
---|
| 303 | foreach filename [glob -nocomplain [file join {*}$widgetInfo($address-folder) *.html] ] { |
---|
| 304 | file delete -force $filename |
---|
| 305 | } |
---|
| 306 | foreach filename [glob -nocomplain [file join {*}$widgetInfo($address-folder) *.txt] ] { |
---|
| 307 | file delete -force $filename |
---|
| 308 | } |
---|
| 309 | |
---|
| 310 | # saving comparisons |
---|
| 311 | set index 1 |
---|
| 312 | set items [llength $current_variable] |
---|
| 313 | foreach selectedpair $current_variable { |
---|
| 314 | set widgetInfo($address-statustxt) "Dumping $index/$items..." |
---|
| 315 | update idletasks |
---|
| 316 | |
---|
| 317 | set file1 [join [ split [ lindex [ split $selectedpair "@"] 0 ] "#" ] "_"] |
---|
| 318 | set file2 [join [ split [ lindex [ split $selectedpair "@"] 1 ] "#" ] "_"] |
---|
| 319 | grapher_create $win $address $win.gr.can $win.tv.tv [file join {*}$widgetInfo($address-folder)] "$file1" "$file2" 1 |
---|
| 320 | incr index |
---|
| 321 | } |
---|
| 322 | |
---|
| 323 | # saving selection |
---|
| 324 | set widgetInfo($address-statustxt) "Dumping Selection Array..." |
---|
| 325 | update idletasks |
---|
| 326 | canvas_makegif $win.t.can [file join {*}$widgetInfo($address-folder) "$widgetInfo($address-name).gif"] |
---|
| 327 | |
---|
| 328 | set widgetInfo($address-status) 1 |
---|
| 329 | set widgetInfo($address-statustxt) "Comparisons data are saved!" |
---|
| 330 | $win.gr.c.statustxt configure -image icon_ok |
---|
| 331 | } |
---|
| 332 | |
---|
| 333 | proc comparator_showlocation {win address} { |
---|
| 334 | global widgetInfo |
---|
| 335 | $win.t.can delete "pointer" |
---|
| 336 | set x [$win.t.can canvasx [expr {[winfo pointerx $win.t.can] - [winfo rootx $win.t.can]}]] |
---|
| 337 | set y [$win.t.can canvasy [expr {[winfo pointery $win.t.can] - [winfo rooty $win.t.can]}]] |
---|
| 338 | |
---|
| 339 | if {$x < 0} {return} |
---|
| 340 | if {$y < 0} {return} |
---|
| 341 | |
---|
| 342 | set boxsize $widgetInfo($address-boxsize) |
---|
| 343 | set col [expr {int($x*1.0/$boxsize)}] |
---|
| 344 | set row [expr {int($y*1.0/$boxsize)}] |
---|
| 345 | |
---|
| 346 | set maxcol [expr {[llength $widgetInfo($address-requiredValue) ]-1}] |
---|
| 347 | |
---|
| 348 | if {$col < $row} {return} |
---|
| 349 | if {$col > $maxcol} {return} |
---|
| 350 | if {$row > $maxcol} {return} |
---|
| 351 | |
---|
| 352 | set runcol [lindex $widgetInfo($address-requiredValue) $col] |
---|
| 353 | set runrow [lindex $widgetInfo($address-requiredValue) $row] |
---|
| 354 | if {$col == $row} { |
---|
| 355 | set widgetInfo($address-position) "$runcol" |
---|
| 356 | } else { |
---|
| 357 | set widgetInfo($address-position) "$runrow \n .vs. \n $runcol " |
---|
| 358 | } |
---|
| 359 | canvas_text_highlighted $win.t.can $x $y $widgetInfo($address-position) "pointer" |
---|
| 360 | } |
---|
| 361 | |
---|
| 362 | |
---|
| 363 | |
---|
| 364 | proc comparator_check {win address} { |
---|
| 365 | global widgetInfo |
---|
| 366 | |
---|
| 367 | #canvas_makegif $win.t.can $address "$widgetInfo($address-name).gif" |
---|
| 368 | |
---|
| 369 | } |
---|
| 370 | |
---|
| 371 | |
---|
| 372 | |
---|
| 373 | |
---|
| 374 | # Copyright CERFACS 2014 |
---|
| 375 | # |
---|
| 376 | # antoine.dauptain@cerfacs.fr |
---|
| 377 | # |
---|
| 378 | # This software is a computer program whose purpose is to ensure technology |
---|
| 379 | # transfer between academia and industry. |
---|
| 380 | # |
---|
| 381 | # This software is governed by the CeCILL-B license under French law and |
---|
| 382 | # abiding by the rules of distribution of free software. You can use, |
---|
| 383 | # modify and/ or redistribute the software under the terms of the CeCILL-B |
---|
| 384 | # license as circulated by CEA, CNRS and INRIA at the following URL |
---|
| 385 | # "http://www.cecill.info". |
---|
| 386 | # |
---|
| 387 | # As a counterpart to the access to the source code and rights to copy, |
---|
| 388 | # modify and redistribute granted by the license, users are provided only |
---|
| 389 | # with a limited warranty and the software's author, the holder of the |
---|
| 390 | # economic rights, and the successive licensors have only limited |
---|
| 391 | # liability. |
---|
| 392 | # |
---|
| 393 | # In this respect, the user's attention is drawn to the risks associated |
---|
| 394 | # with loading, using, modifying and/or developing or reproducing the |
---|
| 395 | # software by the user in light of its specific status of free software, |
---|
| 396 | # that may mean that it is complicated to manipulate, and that also |
---|
| 397 | # therefore means that it is reserved for developers and experienced |
---|
| 398 | # professionals having in-depth computer knowledge. Users are therefore |
---|
| 399 | # encouraged to load and test the software's suitability as regards their |
---|
| 400 | # requirements in conditions enabling the security of their systems and/or |
---|
| 401 | # data to be ensured and, more generally, to use and operate it in the |
---|
| 402 | # same conditions as regards security. |
---|
| 403 | # |
---|
| 404 | # The fact that you are presently reading this means that you have had |
---|
| 405 | # knowledge of the CeCILL-B license and that you accept its terms. |
---|