Blame examples/frameview.pl

Packit 06404a
#!/usr/bin/perl -w 
Packit 06404a
use strict;
Packit 06404a
use Tk;
Packit 06404a
use Tk::Xrm;
Packit 06404a
use Tk qw(exit); 
Packit 06404a
Packit 06404a
my $version="Analyzer 20020429";
Packit 06404a
Packit 06404a
my %bases;
Packit 06404a
my $first_file=undef;
Packit 06404a
my $last_file=undef;
Packit 06404a
my $fileno=0;
Packit 06404a
Packit 06404a
my @panel_labels;
Packit 06404a
my @panel_ones;
Packit 06404a
my @panel_twos;
Packit 06404a
my @panel_onevars;
Packit 06404a
my @panel_twovars;
Packit 06404a
my @panel_keys;
Packit 06404a
my $panel_count;
Packit 06404a
Packit 06404a
# pop the toplevels
Packit 06404a
Packit 06404a
my $toplevel=new MainWindow(-class=>'AnalyzerGraph');
Packit 06404a
my $Xname=$toplevel->Class;
Packit 06404a
$toplevel->optionAdd("$Xname.geometry",  "800x600",20);
Packit 06404a
Packit 06404a
my $geometry=$toplevel->optionGet('geometry','');
Packit 06404a
$geometry=~/^(\d+)x(\d+)/;
Packit 06404a
Packit 06404a
$toplevel->configure(-width=>$1);
Packit 06404a
$toplevel->configure(-height=>$2);
Packit 06404a
Packit 06404a
Packit 06404a
Packit 06404a
Packit 06404a
Packit 06404a
$toplevel->optionAdd("$Xname.background",  "#4fc627",20);
Packit 06404a
$toplevel->optionAdd("$Xname*highlightBackground",  "#80c0d3",20);
Packit 06404a
$toplevel->optionAdd("$Xname.Panel.background",  "#4fc627",20);
Packit 06404a
$toplevel->optionAdd("$Xname.Panel.foreground",  "#d0d0d0",20);
Packit 06404a
$toplevel->optionAdd("$Xname.Panel.font",
Packit 06404a
                     '-*-helvetica-bold-r-*-*-18-*-*-*-*-*-*-*',20);
Packit 06404a
$toplevel->optionAdd("$Xname*Statuslabel.font",
Packit 06404a
                     '-*-helvetica-bold-r-*-*-18-*-*-*-*-*-*-*',20);
Packit 06404a
$toplevel->optionAdd("$Xname*Statuslabel.foreground", "#606060");
Packit 06404a
$toplevel->optionAdd("$Xname*Status.font",
Packit 06404a
                     '-*-helvetica-bold-r-*-*-18-*-*-*-*-*-*-*',20);
Packit 06404a
Packit 06404a
$toplevel->optionAdd("$Xname*AlertDetail.font",
Packit 06404a
                     '-*-helvetica-medium-r-*-*-10-*-*-*-*-*-*-*',20);
Packit 06404a
Packit 06404a
Packit 06404a
$toplevel->optionAdd("$Xname*background",  "#d0d0d0",20);
Packit 06404a
$toplevel->optionAdd("$Xname*foreground",  '#000000',20);
Packit 06404a
Packit 06404a
$toplevel->optionAdd("$Xname*Button*background",  "#f0d0b0",20);
Packit 06404a
$toplevel->optionAdd("$Xname*Button*foreground",  '#000000',20);
Packit 06404a
$toplevel->optionAdd("$Xname*Button*borderWidth",  '2',20);
Packit 06404a
$toplevel->optionAdd("$Xname*Button*relief",  'groove',20);
Packit 06404a
$toplevel->optionAdd("$Xname*Button*padY",  1,20);
Packit 06404a
Packit 06404a
#$toplevel->optionAdd("$Xname*Scale*background",  "#f0d0b0",20);
Packit 06404a
$toplevel->optionAdd("$Xname*Scale*foreground",  '#000000',20);
Packit 06404a
$toplevel->optionAdd("$Xname*Scale*borderWidth",  '1',20);
Packit 06404a
#$toplevel->optionAdd("$Xname*Scale*relief",  'groove',20);
Packit 06404a
$toplevel->optionAdd("$Xname*Scale*padY",  1,20);
Packit 06404a
Packit 06404a
$toplevel->optionAdd("$Xname*Checkbutton*background",  "#f0d0b0",20);
Packit 06404a
$toplevel->optionAdd("$Xname*Checkbutton*foreground",  '#000000',20);
Packit 06404a
$toplevel->optionAdd("$Xname*Checkbutton*borderWidth",  '2',20);
Packit 06404a
$toplevel->optionAdd("$Xname*Checkbutton*relief",  'groove',20);
Packit 06404a
Packit 06404a
$toplevel->optionAdd("$Xname*activeBackground",  "#ffffff",20);
Packit 06404a
$toplevel->optionAdd("$Xname*activeForeground",  '#0000a0',20);
Packit 06404a
$toplevel->optionAdd("$Xname*borderWidth",         0,20);
Packit 06404a
$toplevel->optionAdd("$Xname*relief",         'flat',20);
Packit 06404a
$toplevel->optionAdd("$Xname*activeBorderWidth",         1,20);
Packit 06404a
$toplevel->optionAdd("$Xname*highlightThickness",         0,20);
Packit 06404a
$toplevel->optionAdd("$Xname*padX",         2,20);
Packit 06404a
$toplevel->optionAdd("$Xname*padY",         2,20);
Packit 06404a
$toplevel->optionAdd("$Xname*font",    
Packit 06404a
                     '-*-helvetica-bold-r-*-*-12-*-*-*-*-*-*-*',20);
Packit 06404a
$toplevel->optionAdd("$Xname*Entry.font",    
Packit 06404a
                     '-*-helvetica-medium-r-*-*-12-*-*-*-*-*-*-*',20);
Packit 06404a
$toplevel->optionAdd("$Xname*Exit.font",    
Packit 06404a
                     '-*-helvetica-bold-r-*-*-10-*-*-*-*-*-*-*',20);
Packit 06404a
$toplevel->optionAdd("$Xname*Exit.relief",          'groove',20);
Packit 06404a
$toplevel->optionAdd("$Xname*Exit.padX",          1,20);
Packit 06404a
$toplevel->optionAdd("$Xname*Exit.padY",          1,20);
Packit 06404a
$toplevel->optionAdd("$Xname*Exit.borderWidth",          2,20);
Packit 06404a
$toplevel->optionAdd("$Xname*Exit*background",  "#a0a0a0",20);
Packit 06404a
$toplevel->optionAdd("$Xname*Exit*disabledForeground",  "#ffffff",20);
Packit 06404a
Packit 06404a
#$toplevel->optionAdd("$Xname*Canvas.background",  "#c0c0c0",20);
Packit 06404a
Packit 06404a
$toplevel->optionAdd("$Xname*Entry.background",  "#ffffff",20);
Packit 06404a
$toplevel->optionAdd("$Xname*Entry.disabledForeground",  "#c0c0c0",20);
Packit 06404a
$toplevel->optionAdd("$Xname*Entry.relief",  "sunken",20);
Packit 06404a
$toplevel->optionAdd("$Xname*Entry.borderWidth",  1,20);
Packit 06404a
Packit 06404a
$toplevel->optionAdd("$Xname*Field.background",  "#ffffff",20);
Packit 06404a
$toplevel->optionAdd("$Xname*Field.disabledForeground",  "#c0c0c0",20);
Packit 06404a
$toplevel->optionAdd("$Xname*Field.relief",  "flat",20);
Packit 06404a
$toplevel->optionAdd("$Xname*Field.borderWidth",  1,20);
Packit 06404a
Packit 06404a
$toplevel->optionAdd("$Xname*Label.disabledForeground",  "#c0c0c0",20);
Packit 06404a
$toplevel->optionAdd("$Xname*Label.borderWidth",  1,20);
Packit 06404a
Packit 06404a
$toplevel->configure(-background=>$toplevel->optionGet("background",""));
Packit 06404a
Packit 06404a
#$toplevel->resizable(FALSE,FALSE);
Packit 06404a
Packit 06404a
my $panel=new MainWindow(-class=>'AnalyzerPanel');
Packit 06404a
my $X2name=$panel->Class;
Packit 06404a
Packit 06404a
$panel->optionAdd("$X2name.background",  "#353535",20);
Packit 06404a
$panel->optionAdd("$X2name*highlightBackground",  "#80c0d3",20);
Packit 06404a
$panel->optionAdd("$X2name.Panel.background",  "#353535",20);
Packit 06404a
$panel->optionAdd("$X2name.Panel.foreground",  "#4fc627",20);
Packit 06404a
$panel->optionAdd("$X2name.Panel.font",
Packit 06404a
                     '-*-helvetica-bold-o-*-*-18-*-*-*-*-*-*-*',20);
Packit 06404a
$panel->optionAdd("$X2name*Statuslabel.font",
Packit 06404a
                     '-*-helvetica-bold-r-*-*-18-*-*-*-*-*-*-*',20);
Packit 06404a
$panel->optionAdd("$X2name*Statuslabel.foreground", "#4fc627",20);
Packit 06404a
$panel->optionAdd("$X2name*Status.font",
Packit 06404a
                     '-*-helvetica-bold-r-*-*-18-*-*-*-*-*-*-*',20);
Packit 06404a
Packit 06404a
$panel->optionAdd("$X2name*AlertDetail.font",
Packit 06404a
                     '-*-helvetica-medium-r-*-*-10-*-*-*-*-*-*-*',20);
Packit 06404a
Packit 06404a
Packit 06404a
$panel->optionAdd("$X2name*background",  "#d0d0d0",20);
Packit 06404a
$panel->optionAdd("$X2name*foreground",  '#000000',20);
Packit 06404a
Packit 06404a
$panel->optionAdd("$X2name*Button*background",  "#f0d0b0",20);
Packit 06404a
$panel->optionAdd("$X2name*Button*foreground",  '#000000',20);
Packit 06404a
$panel->optionAdd("$X2name*Button*borderWidth",  '2',20);
Packit 06404a
$panel->optionAdd("$X2name*Button*relief",  'groove',20);
Packit 06404a
$panel->optionAdd("$X2name*Button*padY",  1,20);
Packit 06404a
Packit 06404a
$panel->optionAdd("$X2name*Checkbutton*background",  "#f0d0b0",20);
Packit 06404a
$panel->optionAdd("$X2name*Checkbutton*foreground",  '#000000',20);
Packit 06404a
$panel->optionAdd("$X2name*Checkbutton*borderWidth",  '2',20);
Packit 06404a
#$panel->optionAdd("$X2name*Checkbutton*padX",  '0',20);
Packit 06404a
#$panel->optionAdd("$X2name*Checkbutton*padY",  '0',20);
Packit 06404a
#$panel->optionAdd("$X2name*Checkbutton*relief",  'groove',20);
Packit 06404a
Packit 06404a
$panel->optionAdd("$X2name*activeBackground",  "#ffffff",20);
Packit 06404a
$panel->optionAdd("$X2name*activeForeground",  '#0000a0',20);
Packit 06404a
$panel->optionAdd("$X2name*borderWidth",         0,20);
Packit 06404a
$panel->optionAdd("$X2name*relief",         'flat',20);
Packit 06404a
$panel->optionAdd("$X2name*activeBorderWidth",         1,20);
Packit 06404a
$panel->optionAdd("$X2name*highlightThickness",         0,20);
Packit 06404a
$panel->optionAdd("$X2name*padX",         2,20);
Packit 06404a
$panel->optionAdd("$X2name*padY",         2,20);
Packit 06404a
$panel->optionAdd("$X2name*font",    
Packit 06404a
                     '-*-helvetica-bold-r-*-*-12-*-*-*-*-*-*-*',20);
Packit 06404a
$panel->optionAdd("$X2name*Entry.font",    
Packit 06404a
                     '-*-helvetica-medium-r-*-*-12-*-*-*-*-*-*-*',20);
Packit 06404a
Packit 06404a
$panel->optionAdd("$X2name*Exit.font",    
Packit 06404a
                     '-*-helvetica-bold-r-*-*-10-*-*-*-*-*-*-*',20);
Packit 06404a
$panel->optionAdd("$X2name*Exit.relief",          'groove',20);
Packit 06404a
$panel->optionAdd("$X2name*Exit.padX",          1,20);
Packit 06404a
$panel->optionAdd("$X2name*Exit.padY",          1,20);
Packit 06404a
$panel->optionAdd("$X2name*Exit.borderWidth",          2,20);
Packit 06404a
$panel->optionAdd("$X2name*Exit*background",  "#a0a0a0",20);
Packit 06404a
$panel->optionAdd("$X2name*Exit*disabledForeground",  "#ffffff",20);
Packit 06404a
Packit 06404a
$panel->optionAdd("$X2name*Entry.background",  "#ffffff",20);
Packit 06404a
$panel->optionAdd("$X2name*Entry.disabledForeground",  "#c0c0c0",20);
Packit 06404a
$panel->optionAdd("$X2name*Entry.relief",  "sunken",20);
Packit 06404a
$panel->optionAdd("$X2name*Entry.borderWidth",  1,20);
Packit 06404a
Packit 06404a
$panel->optionAdd("$X2name*Field.background",  "#ffffff",20);
Packit 06404a
$panel->optionAdd("$X2name*Field.disabledForeground",  "#c0c0c0",20);
Packit 06404a
$panel->optionAdd("$X2name*Field.relief",  "flat",20);
Packit 06404a
$panel->optionAdd("$X2name*Field.borderWidth",  1,20);
Packit 06404a
Packit 06404a
$panel->optionAdd("$X2name*Label.disabledForeground",  "#c0c0c0",20);
Packit 06404a
$panel->optionAdd("$X2name*Label.borderWidth",  1,20);
Packit 06404a
Packit 06404a
$panel->configure(-background=>$panel->optionGet("background",""));
Packit 06404a
Packit 06404a
#$panel->resizable("FALSE","FALSE");
Packit 06404a
Packit 06404a
my $panel_shell=$panel->Label(Name=>"shell",-borderwidth=>1,-relief=>'raised')->
Packit 06404a
    place(-x=>10,-y=>36,-relwidth=>1.0,-relheight=>1.0,
Packit 06404a
          -width=>-20,-height=>-46,-anchor=>'nw');
Packit 06404a
Packit 06404a
my $panel_quit=$panel_shell->Button(-class=>"Exit",-text=>"quit",-command=>[sub{Shutdown()}])->
Packit 06404a
    place(-x=>-1,-y=>-1,-relx=>1.0,-rely=>1.0,-anchor=>'se');
Packit 06404a
Packit 06404a
$panel->Label(Name=>"logo text",-class=>"Panel",-text=>$version)->
Packit 06404a
    place(-x=>5,-y=>5,-anchor=>'nw');
Packit 06404a
Packit 06404a
Packit 06404a
my $graph_shell=$toplevel->Label(Name=>"shell",-borderwidth=>1,-relief=>'raised')->
Packit 06404a
    place(-x=>10,-y=>36,-relwidth=>1.0,-relheight=>1.0,
Packit 06404a
          -width=>-20,-height=>-46,-anchor=>'nw');
Packit 06404a
Packit 06404a
my $graph_status=$toplevel->Label(Name=>"logo text",-class=>"Panel",-text=>"Starting up")->
Packit 06404a
    place(-x=>5,-y=>5,-anchor=>'nw');
Packit 06404a
Packit 06404a
Packit 06404a
my $panely=5;
Packit 06404a
my $panel_rescan=$panel_shell->Button(-text=>"rescan",-command=>[sub{scan_directory()}])->
Packit 06404a
    place(-x=>-5,-relx=>1.,-y=>$panely,-anchor=>'ne');
Packit 06404a
$panely+=$panel_rescan->reqheight()+6;
Packit 06404a
Packit 06404a
Packit 06404a
my$temp=$graph_shell->Button(-text=>"<<",
Packit 06404a
		     -command=>[sub{$fileno-=10;$fileno=$first_file if($fileno<$first_file);
Packit 06404a
				load_graph();}])->
Packit 06404a
    place(-x=>5,-y=>-5,-rely=>1.,-relwidth=>.2,-width=>-5,-anchor=>'sw');
Packit 06404a
$graph_shell->Button(-text=>">>",
Packit 06404a
		     -command=>[sub{$fileno+=10;$fileno=$last_file if($fileno>$last_file);
Packit 06404a
				load_graph();}])->
Packit 06404a
    place(-x=>-5,-y=>-5,-relwidth=>.2,-rely=>1.,-width=>-5,-relx=>1.,-anchor=>'se');
Packit 06404a
$graph_shell->Button(-text=>"<",
Packit 06404a
		     -command=>[sub{$fileno-=1;$fileno=$first_file if($fileno<$first_file);
Packit 06404a
				load_graph();}])->
Packit 06404a
    place(-x=>5,-y=>-5,-relwidth=>.3,-width=>-7,-rely=>1.,-relx=>.2,-anchor=>'sw');
Packit 06404a
$graph_shell->Button(-text=>">",
Packit 06404a
		     -command=>[sub{$fileno+=1;$fileno=$last_file if($fileno>$last_file);
Packit 06404a
				load_graph();}])->
Packit 06404a
    place(-x=>-5,-y=>-5,-relwidth=>.3,-width=>-7,-rely=>1.,-relx=>.8,-anchor=>'se');
Packit 06404a
my$graphy=-10-$temp->reqheight();
Packit 06404a
my$graph_slider=$temp=$graph_shell->Scale(-bigincrement=>1,
Packit 06404a
				    -resolution=>1,
Packit 06404a
				    -showvalue=>'TRUE',-variable=>\$fileno,-orient=>'horizontal')->
Packit 06404a
    place(-x=>5,-y=>$graphy,-relwidth=>1.,-rely=>1.,-width=>-10,-anchor=>'sw');
Packit 06404a
$graphy-=$temp->reqheight()+5;
Packit 06404a
Packit 06404a
my$onecrop;
Packit 06404a
my$twocrop;
Packit 06404a
Packit 06404a
my$oneresize=$temp=$graph_shell->Checkbutton(-text=>"rescale",-variable=>\$onecrop,
Packit 06404a
				-command=>[sub{draw_graph();}])->
Packit 06404a
    place(-x=>5,-y=>5,-anchor=>'nw');
Packit 06404a
Packit 06404a
my$one=$graph_shell->Canvas()->
Packit 06404a
    place(-relwidth=>1.,-width=>-10,-relheight=>.5,-height=>($graphy/2)-5-$temp->reqheight(),
Packit 06404a
				     -x=>5,-y=>5+$temp->reqheight,-anchor=>'nw');
Packit 06404a
Packit 06404a
Packit 06404a
my$tworesize=$temp=$graph_shell->Checkbutton(-text=>"rescale",-variable=>\$twocrop,
Packit 06404a
				-command=>[sub{draw_graph();}])->
Packit 06404a
    place(-rely=>1.,-y=>5,-anchor=>'nw',-in=>$one);
Packit 06404a
my$two=$graph_shell->Canvas()->
Packit 06404a
    place(-relwidth=>1.,-relheight=>1.,-rely=>1.,-y=>5+$temp->reqheight(),-anchor=>'nw',-in=>$one);
Packit 06404a
Packit 06404a
scan_directory();
Packit 06404a
Packit 06404a
my%onestate;
Packit 06404a
my%twostate;
Packit 06404a
my @data;
Packit 06404a
Packit 06404a
$onestate{"canvas"}=$one;
Packit 06404a
$onestate{"vars"}=\@panel_onevars;
Packit 06404a
$twostate{"canvas"}=$two;
Packit 06404a
$twostate{"vars"}=\@panel_twovars;
Packit 06404a
Packit 06404a
$graph_slider->configure(-command=>[sub{load_graph()}]);
Packit 06404a
load_graph();
Packit 06404a
$toplevel->bind('MainWindow','<Configure>',[sub{$toplevel->update();
Packit 06404a
						draw_graph()}]);
Packit 06404a
Packit 06404a
Tk::MainLoop();
Packit 06404a
Packit 06404a
sub load_graph{
Packit 06404a
Packit 06404a
    scan_directory()if(!defined($panel_count));
Packit 06404a
Packit 06404a
    @data=undef;
Packit 06404a
    
Packit 06404a
    for(my$i=0;$i<$panel_count;$i++){
Packit 06404a
	my$filename=$panel_keys[$i]."_$fileno.m";
Packit 06404a
	if(open F, "$filename"){
Packit 06404a
	    $data[$i]=[(<F>)];
Packit 06404a
	    close F;
Packit 06404a
	}
Packit 06404a
    }
Packit 06404a
    draw_graph();
Packit 06404a
}
Packit 06404a
Packit 06404a
sub graphhelper{
Packit 06404a
    my($graph)=@_;
Packit 06404a
    my$count=0;
Packit 06404a
    my@colors=("#ff0000","#00df00","#0000ff","#ffff00","#ff00ff","#00ffff","#ffffff",
Packit 06404a
	       "#9f0000","#007f00","#00009f","#8f8f00","#8f008f","#008f8f","#000000");
Packit 06404a
    
Packit 06404a
    my$w=$graph->{"canvas"};
Packit 06404a
    my$rescale=0;
Packit 06404a
Packit 06404a
    Status("Plotting $fileno");
Packit 06404a
    $w->delete('foo');
Packit 06404a
    $w->delete('legend');
Packit 06404a
    $w->delete('lines');
Packit 06404a
Packit 06404a
    # count range 
Packit 06404a
    for(my$i=0;$i<$panel_count;$i++){
Packit 06404a
	if($graph->{"vars"}->[$i]){
Packit 06404a
	    if(defined($data[$i])){
Packit 06404a
		if(!defined($graph->{"minx"})){
Packit 06404a
		    $data[$i]->[0]=~m/^\s*(-?[0-9\.]*)[ ,]+(-?[0-9\.]*)/;
Packit 06404a
		    $graph->{"maxx"}=$1;
Packit 06404a
		    $graph->{"minx"}=$1;
Packit 06404a
		    $graph->{"maxy"}=$2;
Packit 06404a
		    $graph->{"miny"}=$2;
Packit 06404a
		    $rescale=1;
Packit 06404a
		}
Packit 06404a
		
Packit 06404a
		for(my$j=0;$j<=$#{$data[$i]};$j++){
Packit 06404a
		    $data[$i]->[$j]=~m/^\s*(-?[0-9\.]*)[ ,]+(-?[0-9\.]*)/;
Packit 06404a
		    $rescale=1 if($1>$graph->{"maxx"});
Packit 06404a
		    $rescale=1 if($1<$graph->{"minx"});
Packit 06404a
		    $rescale=1 if($2>$graph->{"maxy"});
Packit 06404a
		    $rescale=1 if($2<$graph->{"miny"});
Packit 06404a
		    $graph->{"maxx"}=$1 if($1>$graph->{"maxx"});
Packit 06404a
		    $graph->{"minx"}=$1 if($1<$graph->{"minx"});
Packit 06404a
		    $graph->{"maxy"}=$2 if($2>$graph->{"maxy"});
Packit 06404a
		    $graph->{"miny"}=$2 if($2<$graph->{"miny"});
Packit 06404a
		}
Packit 06404a
	    }
Packit 06404a
	    $count++;
Packit 06404a
	}
Packit 06404a
    }
Packit 06404a
Packit 06404a
    my$width=$w->width();
Packit 06404a
    my$height=$w->height();
Packit 06404a
Packit 06404a
    $rescale=1 if(!defined($graph->{"width"}) || 
Packit 06404a
		  $width!=$graph->{"width"} || 
Packit 06404a
		  $height!=$graph->{"height"});
Packit 06404a
    
Packit 06404a
    $graph->{"width"}=$width; 
Packit 06404a
    $graph->{"height"}=$height; 
Packit 06404a
Packit 06404a
    if(defined($graph->{"maxx"})){
Packit 06404a
	# draw axes, labels
Packit 06404a
	# look for appropriate axis scales
Packit 06404a
Packit 06404a
	if($rescale){
Packit 06404a
Packit 06404a
	    $w->delete('ylabel');
Packit 06404a
	    $w->delete('xlabel');
Packit 06404a
	    $w->delete('axes');
Packit 06404a
	    
Packit 06404a
	    my$yscale=1.;
Packit 06404a
	    my$xscale=1.;
Packit 06404a
	    my$iyscale=1.;
Packit 06404a
	    my$ixscale=1.;
Packit 06404a
	    while(($graph->{"maxx"}-$graph->{"minx"})*$xscale>15){$xscale*=.1;$ixscale*=10.;}
Packit 06404a
	    while(($graph->{"maxy"}-$graph->{"miny"})*$yscale>15){$yscale*=.1;$iyscale*=10.;}
Packit 06404a
	    
Packit 06404a
	    while(($graph->{"maxx"}-$graph->{"minx"})*$xscale<3){$xscale*=10.;$ixscale*=.1;}
Packit 06404a
	    while(($graph->{"maxy"}-$graph->{"miny"})*$yscale<3){$yscale*=10.;$iyscale*=.1;}
Packit 06404a
	    
Packit 06404a
	    # how tall are the x axis labels?
Packit 06404a
	    $w->createText(-1,-1,-anchor=>'se',-tags=>['foo'],-text=>"0123456789.");
Packit 06404a
	    my($x1,$y1,$x2,$y2)=$w->bbox('foo');
Packit 06404a
	    $w->delete('foo');
Packit 06404a
	    my$maxlabelheight=$y2-$y1;
Packit 06404a
	    my$useabley=$height-$maxlabelheight-3;
Packit 06404a
	    my$pixelpery=$useabley/($graph->{"maxy"}-$graph->{"miny"});
Packit 06404a
	    
Packit 06404a
	    # place y axis labels at proper spacing/height
Packit 06404a
	    my$lasty=-$maxlabelheight/2;
Packit 06404a
	    my$topyval=int($graph->{"maxy"}*$yscale+1.)*$iyscale;
Packit 06404a
	    
Packit 06404a
	    for(my$i=0;;$i++){
Packit 06404a
		my$yval= $topyval-$i*$iyscale;
Packit 06404a
		my$y= ($graph->{"maxy"}-$yval)*$pixelpery;
Packit 06404a
		last if($y>$useabley);
Packit 06404a
		if($y-$maxlabelheight>=$lasty){
Packit 06404a
		    $w->createText(0,$y,-anchor=>'e',-tags=>['ylabel'],-text=>"$yval");
Packit 06404a
		    $lasty=$y;
Packit 06404a
		}
Packit 06404a
	    }
Packit 06404a
	    
Packit 06404a
	    # get the max ylabel width and place them at proper x
Packit 06404a
	    ($x1,$y1,$x2,$y2)=$w->bbox('ylabel');
Packit 06404a
	    my$maxylabelwidth=$x2-$x1;
Packit 06404a
	    $w->move('ylabel',$maxylabelwidth,0);
Packit 06404a
	    
Packit 06404a
	    my$beginx=$maxylabelwidth+3;
Packit 06404a
	    my$useablex=$width-$beginx;
Packit 06404a
	    
Packit 06404a
	    # draw basic axes
Packit 06404a
	    $w->createLine($beginx,0,$beginx,$useabley,$width,$useabley,
Packit 06404a
			   -tags=>['axes'],-width=>2);
Packit 06404a
	    # draw y tix
Packit 06404a
	    $lasty=-$maxlabelheight/2;
Packit 06404a
	    for(my$i=0;;$i++){
Packit 06404a
		my$yval= $topyval-$i*$iyscale;
Packit 06404a
		my$y= ($graph->{"maxy"}-$yval)*$pixelpery;
Packit 06404a
		last if($y>$useabley);
Packit 06404a
		if($yval==0){
Packit 06404a
		    $w->createLine($beginx,$y,$width,$y,
Packit 06404a
				   -tags=>['axes'],-width=>1);
Packit 06404a
		}else{
Packit 06404a
		    if($y-$maxlabelheight>=$lasty){
Packit 06404a
			$w->createLine($beginx,$y,$width,$y,
Packit 06404a
				       -tags=>['axes'],-width=>1,
Packit 06404a
				       -stipple=>'gray50');
Packit 06404a
			
Packit 06404a
			$lasty=$y;
Packit 06404a
		    }
Packit 06404a
		}
Packit 06404a
	    }
Packit 06404a
	    
Packit 06404a
	    # place x axis labels at proper spacing
Packit 06404a
	    my$topxval=int($graph->{"maxx"}*$xscale+1.)*$ixscale;
Packit 06404a
	    my$pixelperx=$useablex/($graph->{"maxx"}-$graph->{"minx"});
Packit 06404a
	    
Packit 06404a
	    for(my$i=0;;$i++){
Packit 06404a
		my$xval= $topxval-$i*$ixscale;
Packit 06404a
		my$x= $width-($graph->{"maxx"}-$xval)*$pixelperx;
Packit 06404a
		
Packit 06404a
		last if($x<$beginx);
Packit 06404a
		# bounding boxen are hard.  place temp labels.
Packit 06404a
		$w->createText(-1,-1,-anchor=>'e',-tags=>['foo'],-text=>"$xval");
Packit 06404a
	    }
Packit 06404a
	    
Packit 06404a
	    ($x1,$y1,$x2,$y2)=$w->bbox('foo');
Packit 06404a
	    my$maxxlabelwidth=$x2-$x1;
Packit 06404a
	    $w->delete('foo');
Packit 06404a
	    my$lastx=$width;
Packit 06404a
	    
Packit 06404a
	    for(my$i=0;;$i++){
Packit 06404a
		my$xval= $topxval-$i*$ixscale;
Packit 06404a
		my$x= $width-($graph->{"maxx"}-$xval)*$pixelperx;
Packit 06404a
		
Packit 06404a
		last if($x-$maxxlabelwidth/2<0 || $x<$beginx);
Packit 06404a
		if($xval==0 && $x<$width){
Packit 06404a
		    $w->createLine($x,0,$x,$useabley,-tags=>['axes'],-width=>1);
Packit 06404a
		}
Packit 06404a
	    
Packit 06404a
		if($x+$maxxlabelwidth<=$lastx){
Packit 06404a
		    $w->createText($x,$height-1,-anchor=>'s',-tags=>['xlabel'],-text=>"$xval");
Packit 06404a
		    $w->createLine($x,0,$x,$useabley,-tags=>['axes'],-width=>1,-stipple=>"gray50");
Packit 06404a
		    $lastx=$x;
Packit 06404a
		}
Packit 06404a
	    }
Packit 06404a
	    $graph->{"labelheight"}=$maxlabelheight;
Packit 06404a
	    $graph->{"xo"}=$beginx;
Packit 06404a
	    $graph->{"ppx"}=$pixelperx;
Packit 06404a
	    $graph->{"ppy"}=$pixelpery;
Packit 06404a
	}
Packit 06404a
Packit 06404a
	# plot the files
Packit 06404a
	$count=0;
Packit 06404a
	my$legendy=$graph->{"labelheight"}/2;
Packit 06404a
	for(my$i=0;$i<$panel_count;$i++){
Packit 06404a
	    if($graph->{"vars"}->[$i]){
Packit 06404a
		$count++; # count here for legend color selection stability
Packit 06404a
		if(defined($data[$i])){
Packit 06404a
		    # place a legend placard;
Packit 06404a
		    my$color=$colors[($count-1)%($#colors+1)];
Packit 06404a
		    $w->createText($width,$legendy,-anchor=>'e',-tags=>['legend'],
Packit 06404a
				   -fill=>$color,-text=>$panel_keys[$i]);
Packit 06404a
		    $legendy+=$graph->{"labelheight"};
Packit 06404a
Packit 06404a
		    # plot the lines
Packit 06404a
		    my@pairs=map{if(/^\s*(-?[0-9\.]*)[ ,]+(-?[0-9\.]*)/){
Packit 06404a
			(($1-$graph->{"minx"})*$graph->{"ppx"}+$graph->{"xo"},
Packit 06404a
			 (-$2+$graph->{"maxy"})*$graph->{"ppy"})}} (@{$data[$i]});
Packit 06404a
		    
Packit 06404a
		    $w->createLine((@pairs),-fill=>$color,-tags=>['lines']);
Packit 06404a
		}
Packit 06404a
	    }
Packit 06404a
	}
Packit 06404a
    }
Packit 06404a
}    
Packit 06404a
Packit 06404a
sub draw_graph{
Packit 06404a
Packit 06404a
    if($onecrop){
Packit 06404a
	$onestate{"minx"}=undef;
Packit 06404a
	$onestate{"miny"}=undef;
Packit 06404a
	$onestate{"maxx"}=undef;
Packit 06404a
	$onestate{"maxy"}=undef;
Packit 06404a
    }
Packit 06404a
    if($twocrop){
Packit 06404a
	$twostate{"minx"}=undef;
Packit 06404a
	$twostate{"miny"}=undef;
Packit 06404a
	$twostate{"maxx"}=undef;
Packit 06404a
	$twostate{"maxy"}=undef;
Packit 06404a
    }
Packit 06404a
Packit 06404a
    for(my$i=0;$i<$panel_count;$i++){
Packit 06404a
	if($twostate{"vars"}->[$i]){
Packit 06404a
	    
Packit 06404a
	    #re-place the canvases
Packit 06404a
	    
Packit 06404a
	    $oneresize->place(-x=>5,-y=>5,-anchor=>'nw');
Packit 06404a
Packit 06404a
	    $one->place(-relwidth=>1.,-width=>-10,-relheight=>.5,
Packit 06404a
			 -height=>($graphy/2)-5-$oneresize->reqheight(),
Packit 06404a
			 -x=>5,-y=>5+$oneresize->reqheight,-anchor=>'nw');
Packit 06404a
	    
Packit 06404a
	    $tworesize->place(-rely=>1.,-y=>5,-anchor=>'nw',-in=>$one);
Packit 06404a
	    $two->place(-relwidth=>1.,-relheight=>1.,-rely=>1.,
Packit 06404a
			-y=>5+$tworesize->reqheight(),-anchor=>'nw',-in=>$one);
Packit 06404a
Packit 06404a
	    graphhelper(\%onestate);
Packit 06404a
	    graphhelper(\%twostate);
Packit 06404a
	    return;
Packit 06404a
	}
Packit 06404a
    }
Packit 06404a
Packit 06404a
    $oneresize->place(-x=>5,-y=>5,-anchor=>'nw');
Packit 06404a
    
Packit 06404a
    $one->place(-relwidth=>1.,-width=>-10,-relheight=>1.,
Packit 06404a
		 -height=>$graphy-5-$oneresize->reqheight(),
Packit 06404a
		 -x=>5,-y=>5+$oneresize->reqheight,-anchor=>'nw');
Packit 06404a
    
Packit 06404a
    $tworesize->placeForget();
Packit 06404a
    $two->placeForget();
Packit 06404a
Packit 06404a
    graphhelper(\%onestate);
Packit 06404a
}
Packit 06404a
Packit 06404a
sub depopulate_panel{
Packit 06404a
    my $win;
Packit 06404a
    foreach $win (@panel_labels){
Packit 06404a
	$win->destroy();
Packit 06404a
    }
Packit 06404a
    @panel_labels=();
Packit 06404a
    foreach $win (@panel_ones){
Packit 06404a
	$win->destroy();
Packit 06404a
    }
Packit 06404a
    @panel_ones=();
Packit 06404a
    foreach $win (@panel_twos){
Packit 06404a
	$win->destroy();
Packit 06404a
    }
Packit 06404a
    @panel_twos=();
Packit 06404a
    @panel_keys=();
Packit 06404a
}
Packit 06404a
Packit 06404a
sub populate_panel{
Packit 06404a
    my $localy=$panely;
Packit 06404a
    my $key;
Packit 06404a
    my $i=0;
Packit 06404a
    foreach $key (sort (keys %bases)){
Packit 06404a
	$panel_keys[$i]=$key;
Packit 06404a
	if(!defined($panel_onevars[$i])){
Packit 06404a
	    $panel_onevars[$i]=0;
Packit 06404a
	    $panel_twovars[$i]=0;
Packit 06404a
	}
Packit 06404a
Packit 06404a
	my $temp=$panel_twos[$i]=$panel_shell->
Packit 06404a
	    Checkbutton(-variable=>\$panel_twovars[$i],-command=>['main::draw_graph'],-text=>'2')->
Packit 06404a
	    place(-y=>$localy,-x=>-5,-anchor=>"ne",-relx=>1.);
Packit 06404a
	my $oney=$temp->reqheight();
Packit 06404a
	my $onex=$temp->reqwidth()+15;
Packit 06404a
Packit 06404a
	$temp=$panel_ones[$i]=$panel_shell->
Packit 06404a
	    Checkbutton(-variable=>\$panel_onevars[$i],-command=>['main::draw_graph'],-text=>'1')->
Packit 06404a
	    place(-y=>0,-x=>0,-anchor=>"ne",-in=>$temp,-bordermode=>'outside');
Packit 06404a
	$oney=$temp->reqheight() if ($oney<$temp->reqheight());
Packit 06404a
	$onex+=$temp->reqwidth();
Packit 06404a
Packit 06404a
	$temp=$panel_labels[$i]=$panel_shell->Label(-text=>$key,-class=>'Field',-justify=>'left')->
Packit 06404a
	    place(-y=>$localy,-x=>5,-anchor=>"nw",-relwidth=>1.,-width=>-$onex,
Packit 06404a
		  -bordermode=>'outside');
Packit 06404a
	$oney=$temp->reqheight() if ($oney<$temp->reqheight());
Packit 06404a
	
Packit 06404a
	$localy+=$oney+2;
Packit 06404a
	$i++;
Packit 06404a
    }
Packit 06404a
    $panel_count=$i;    
Packit 06404a
Packit 06404a
    $localy+=$panel_quit->reqheight()+50;
Packit 06404a
    my $geometry=$panel->geometry();
Packit 06404a
    $geometry=~/^(\d+)/;
Packit 06404a
Packit 06404a
    $panel->configure(-height=>$localy);
Packit 06404a
    $panel->configure(-width=>$1);
Packit 06404a
}
Packit 06404a
Packit 06404a
sub Shutdown{
Packit 06404a
  Tk::exit();
Packit 06404a
}
Packit 06404a
Packit 06404a
sub Status{
Packit 06404a
    my$text=shift @_;
Packit 06404a
    $graph_status->configure(-text=>"$text");
Packit 06404a
    $toplevel->update();
Packit 06404a
}
Packit 06404a
Packit 06404a
sub scan_directory{
Packit 06404a
    
Packit 06404a
    %bases=();
Packit 06404a
    my$count=0;
Packit 06404a
Packit 06404a
    $first_file=undef;
Packit 06404a
    $last_file=undef;
Packit 06404a
Packit 06404a
    if(opendir(D,".")){
Packit 06404a
        my$file;
Packit 06404a
        while(defined($file=readdir(D))){
Packit 06404a
	    if($file=~m/^(\S*)_(\d+).m/){
Packit 06404a
		$bases{"$1"}="0";
Packit 06404a
		$first_file=$2 if(!defined($first_file) || $2<$first_file);
Packit 06404a
		$last_file=$2 if(!defined($last_file) || $2>$last_file);
Packit 06404a
		$count++;
Packit 06404a
		
Packit 06404a
		Status("Reading... $count")if($count%117==0);
Packit 06404a
	    }
Packit 06404a
        }	
Packit 06404a
        closedir(D);
Packit 06404a
    }
Packit 06404a
    Status("Done Reading: $count files");
Packit 06404a
    depopulate_panel();
Packit 06404a
    populate_panel();
Packit 06404a
    
Packit 06404a
    $fileno=$first_file if($fileno<$first_file);
Packit 06404a
    $fileno=$last_file if($fileno>$last_file);
Packit 06404a
Packit 06404a
    $graph_slider->configure(-from=>$first_file,-to=>$last_file);
Packit 06404a
Packit 06404a
}
Packit 06404a
Packit 06404a
Packit 06404a
Packit 06404a
Packit 06404a