X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~yarrgweb/git?p=ypp-sc-tools.db-live.git;a=blobdiff_plain;f=yarrg%2Fwhere-vessels;h=7e64cce85e60a5d97401fee79a8fc025c8e54e31;hp=c6636d6a96ff20bcf6c45eddf370dc4396ca874a;hb=84e330af6dabd818db6e87e0ff57db45fdf176ca;hpb=5ec8840d7a85a2eb96eea32c50c1139c83f92c70 diff --git a/yarrg/where-vessels b/yarrg/where-vessels index c6636d6..7e64cce 100755 --- a/yarrg/where-vessels +++ b/yarrg/where-vessels @@ -304,14 +304,16 @@ proc vesselclasses-init {} { } proc load-icon {icon} { - image create bitmap icon/$icon -file icons/$icon.xbm + global info_cache + image create bitmap icon/$icon -file $info_cache/$icon.xbm } proc load-icon-combine {args} { + global info_cache set cmd {} set delim "pnmcat -lr " foreach icon $args { - append cmd $delim " <(xbmtopbm icons/$icon.xbm)" + append cmd $delim " <(xbmtopbm $info_cache/$icon.xbm)" set delim " <(pbmmake -white 1 1)" } append cmd " | pbmtoxbm" @@ -361,8 +363,14 @@ proc code2canvas {code canvas x yvar qty qtylen bind} { incr stackx } + upvar #0 vc_code2abbrev($class) vcabb + if {![info exists vcabb]} { + set vcabb vc-$class + image create bitmap icon/$vcabb -data \ + [exec pbmtext -builtin fixed $class | pnminvert | pnmcrop >t.pnm] + } canvas-horiz-stack stackx -1 $imy $bind \ - image -anchor nw -image icon/$vc_code2abbrev($class) + image -anchor nw -image icon/$vcabb if {[string length $subclass]} { canvas-horiz-stack stackx 0 $y $bind \ @@ -602,7 +610,18 @@ proc vessel {vin} { set gameclass [errexpect-arrayget vi vesselClass] upvar #0 vc_game2code($gameclass) class - if {![info exists class]} { errexpect-error "unexpected vesselClass"} + if {![info exists class]} { + set class "($gameclass)" + upvar #0 vc_code2abbrev($class) vcabb + set vcabb vc-$class + set data [exec pbmtext -builtin fixed " $gameclass " \ + | pnminvert | pnmcrop | pbmtoxbm] + debug "INVENTED ICON $vcabb $data" + image create bitmap icon/$vcabb -data $data + + global vc_code2full + set vc_code2full($class) "Type \"$gameclass\"" + } lappend codel $class set gamesubclass [errexpect-arrayget vi vesselSubclass] @@ -725,7 +744,7 @@ proc load-chart {} { yppedia_chart_parse(\*STDIN, (new IO::File ">/dev/null"), sub { sprintf "%d %d", @_; }, sub { printf "archlabel %d %d %s\n", @_; }, - sub { printf "island %s %s\n", @_; }, + sub { printf "island %s {%s} %s\n", @_; }, sub { printf "league %s %s %s.\n", @_; }, sub { printf STDERR "warning: %s: incomprehensible: %s", @_; } ); @@ -742,17 +761,19 @@ proc coord {c} { } proc chart-got/archlabel {args} { } -proc chart-got/island {x y args} { -# debug "ISLE $x $y $args" +proc chart-got/island {x y isle sizecol} { + debug "ISLE $x $y $isle $sizecol" global canvas isleloc - set isleloc($args) [list $x $y] + set isleloc($isle) [list $x $y] set sz 5 # $canvas create oval \ # [expr {[coord $x] - $sz}] [expr {[coord $y] - $sz}] \ # [expr {[coord $x] + $sz}] [expr {[coord $y] + $sz}] \ # -fill blue + set colour "#888" + if {[string match *_col $sizecol]} { set colour black } $canvas create text [coord $x] [coord $y] \ - -text $args -anchor s + -text $isle -anchor s -fill $colour } proc chart-got/league {x1 y1 x2 y2 kind} { # debug "LEAGUE $x1 $y1 $x2 $y2 $kind"