version 1.140, 2008/05/20 10:53:07
|
version 1.182, 2019/05/08 12:24:27
|
Line 26
|
Line 26
|
# http://www.lon-capa.org/ |
# http://www.lon-capa.org/ |
# |
# |
|
|
|
|
|
|
|
|
package Apache::lonplot; |
package Apache::lonplot; |
|
|
use strict; |
use strict; |
Line 39 use Apache::lonnet;
|
Line 42 use Apache::lonnet;
|
use LONCAPA; |
use LONCAPA; |
|
|
|
|
use vars qw/$weboutputformat $version/; |
use vars qw/$weboutputformat $version $colorprefix/; |
|
|
|
|
|
|
Line 53 BEGIN {
|
Line 56 BEGIN {
|
if ($version >= 4) { |
if ($version >= 4) { |
$weboutputformat = 'png'; |
$weboutputformat = 'png'; |
} |
} |
|
$colorprefix = 'x'; |
|
if ($version > 4.6) { |
|
$colorprefix = '#'; |
|
} |
} |
} |
|
|
|
|
|
=pod |
|
|
## |
## |
## Description of data structures: |
## Description of data structures: |
## |
## |
Line 73 BEGIN {
|
Line 81 BEGIN {
|
## align |
## align |
## |
## |
## @labels: $labels[$i] = \%label |
## @labels: $labels[$i] = \%label |
## %label: text, xpos, ypos, justify |
## %label: text, xpos, ypos, justify, rotate, zlayer |
## |
## |
## @curves: $curves[$i] = \%curve |
## @curves: $curves[$i] = \%curve |
## %curve: name, linestyle, ( function | data ) |
## %curve: name, linestyle, ( function | data ) |
Line 88 BEGIN {
|
Line 96 BEGIN {
|
## ## |
## ## |
################################################################### |
################################################################### |
|
|
|
=cut |
|
|
my $max_str_len = 50; # if a label, title, xlabel, or ylabel text |
my $max_str_len = 50; # if a label, title, xlabel, or ylabel text |
# is longer than this, it will be truncated. |
# is longer than this, it will be truncated. |
|
|
my %linetypes = |
my %linetypes = # For png use these linetypes. |
( |
( |
solid => 1, |
solid => 1, |
dashed => 0 |
dashed => 0 |
); |
); |
|
my %ps_linetypes = # For ps the line types are different! |
|
( |
|
solid => 1, |
|
dashed => 7 |
|
); |
|
|
my %linestyles = |
my %linestyles = |
( |
( |
Line 120 my $real_test =
|
Line 135 my $real_test =
|
sub {$_[0]=~s/\s+//g;$_[0]=~/^[+-]?\d*\.?\d*([eE][+-]\d+)?$/}; |
sub {$_[0]=~s/\s+//g;$_[0]=~/^[+-]?\d*\.?\d*([eE][+-]\d+)?$/}; |
my $pos_real_test = |
my $pos_real_test = |
sub {$_[0]=~s/\s+//g;$_[0]=~/^[+]?\d*\.?\d*([eE][+-]\d+)?$/}; |
sub {$_[0]=~s/\s+//g;$_[0]=~/^[+]?\d*\.?\d*([eE][+-]\d+)?$/}; |
my $color_test = sub {$_[0]=~s/\s+//g;$_[0]=~/^x[\da-fA-F]{6}$/}; |
my $color_test; |
|
if ($version < 4.6) { |
|
$color_test = sub {$_[0]=~s/\s+//g;$_[0]=~s/^\#/x/;$_[0]=~/^x[\da-fA-F]{6}$/}; |
|
} else { |
|
$color_test = sub {$_[0]=~s/\s+//g;$_[0]=~s/^x/#/;$_[0]=~/^\#[\da-fA-F]{6}$/}; |
|
} |
my $onoff_test = sub {$_[0]=~/^(on|off)$/}; |
my $onoff_test = sub {$_[0]=~/^(on|off)$/}; |
my $key_pos_test = sub {$_[0]=~/^(top|bottom|right|left|outside|below| )+$/}; |
my $key_pos_test = sub {$_[0]=~/^(top|bottom|right|left|outside|below| )+$/}; |
my $sml_test = sub {$_[0]=~/^(\d+|small|medium|large)$/}; |
my $sml_test = sub {$_[0]=~/^(\d+|small|medium|large)$/}; |
my $linestyle_test = sub {exists($linestyles{$_[0]})}; |
my $linestyle_test = sub {exists($linestyles{$_[0]})}; |
my $words_test = sub {$_[0]=~s/\s+/ /g;$_[0]=~/^([\w~!\@\#\$\%^&\*\(\)-=_\+\[\]\{\}:\;\'<>,\.\/\?\\]+ ?)+$/}; |
my $words_test = sub {$_[0]=~s/\s+/ /g;$_[0]=~/^([\w~!\@\#\$\%^&\*\(\)-=_\+\[\]\{\}:\;\'<>,\.\/\?\\]+ ?)+$/}; |
|
|
|
my $arrowhead_test = sub{$_[0]=~/^(nohead|head|heads| )+$/}; |
|
my $arrowstyle_test= sub{$_[0]=~/^(filled|empty|nofilled)+$/}; |
|
my $degree_test = sub{&$pos_real_test($_[0]) && ($_[0] <= 360.0)}; |
|
|
################################################################### |
################################################################### |
## ## |
## ## |
## Attribute metadata ## |
## Attribute metadata ## |
Line 165 my %gnuplot_defaults =
|
Line 189 my %gnuplot_defaults =
|
size => '10' |
size => '10' |
}, |
}, |
bgcolor => { |
bgcolor => { |
default => 'xffffff', |
default => $colorprefix.'ffffff', |
test => $color_test, |
test => $color_test, |
description => 'Background color of image (xffffff)', |
description => 'Background color of image ('.$colorprefix.'ffffff)', |
edit_type => 'entry', |
edit_type => 'entry', |
size => '10' |
size => '10', |
|
class => 'colorchooser' |
}, |
}, |
fgcolor => { |
fgcolor => { |
default => 'x000000', |
default => $colorprefix.'000000', |
test => $color_test, |
test => $color_test, |
description => 'Foreground color of image (x000000)', |
description => 'Foreground color of image ('.$colorprefix.'000000)', |
edit_type => 'entry', |
edit_type => 'entry', |
size => '10' |
size => '10', |
|
class => 'colorchooser' |
}, |
}, |
transparent => { |
transparent => { |
default => 'off', |
default => 'off', |
Line 235 my %gnuplot_defaults =
|
Line 261 my %gnuplot_defaults =
|
test => sub {$_[0]=~/^(left|right|middle|center)$/}, |
test => sub {$_[0]=~/^(left|right|middle|center)$/}, |
description => 'Alignment for image in HTML', |
description => 'Alignment for image in HTML', |
edit_type => 'choice', |
edit_type => 'choice', |
choices => ['left','right','middle'] |
choices => ['left','right','middle','center'] |
}, |
}, |
texwidth => { |
texwidth => { |
default => '93', |
default => '93', |
Line 344 my %gnuplot_defaults =
|
Line 370 my %gnuplot_defaults =
|
}, |
}, |
); |
); |
|
|
|
|
my %key_defaults = |
my %key_defaults = |
( |
( |
title => { |
title => { |
Line 398 my %label_defaults =
|
Line 425 my %label_defaults =
|
description => 'Rotation of label (degrees)', |
description => 'Rotation of label (degrees)', |
edit_type => 'entry', |
edit_type => 'entry', |
size => '10', |
size => '10', |
} |
}, |
|
zlayer => { |
|
default => '', |
|
test => sub {$_[0]=~/^(front|back)$/}, |
|
description => 'Z position of label', |
|
edit_type => 'choice', |
|
choices => ['front','back'], |
|
}, |
); |
); |
|
|
my @tic_edit_order = ('location','mirror','start','increment','end', |
my @tic_edit_order = ('location','mirror','start','increment','end', |
Line 445 my %tic_defaults =
|
Line 479 my %tic_defaults =
|
description => 'Number of minor tics per major tic mark', |
description => 'Number of minor tics per major tic mark', |
edit_type => 'entry', |
edit_type => 'entry', |
size => '10' |
size => '10' |
}, |
}, |
|
rotate => { |
|
default => 'off', |
|
test => $onoff_test, |
|
description => 'Rotate tic label by 90 degrees if on', |
|
edit_type => 'onoff' |
|
} |
); |
); |
|
|
my @axis_edit_order = ('color','xmin','xmax','ymin','ymax','xformat', 'yformat'); |
my @axis_edit_order = ('color','xmin','xmax','ymin','ymax','xformat', 'yformat', 'xzero', 'yzero'); |
my %axis_defaults = |
my %axis_defaults = |
( |
( |
color => { |
color => { |
default => 'x000000', |
default => $colorprefix.'000000', |
test => $color_test, |
test => $color_test, |
description => 'Color of grid lines (x000000)', |
description => 'Color of grid lines ('.$colorprefix.'000000)', |
edit_type => 'entry', |
edit_type => 'entry', |
size => '10' |
size => '10', |
|
class => 'colorchooser' |
}, |
}, |
xmin => { |
xmin => { |
default => '-10.0', |
default => '-10.0', |
Line 488 my %axis_defaults =
|
Line 529 my %axis_defaults =
|
}, |
}, |
xformat => { |
xformat => { |
default => 'on', |
default => 'on', |
test => sub {$_[0]=~/^(on|off|\d+(f|F|e|E))$/}, |
test => sub {$_[0]=~/^(on|off|\d+(f|F|e|E|P(|\s*\Q\0317\0200\E)))$/}, |
description => 'X-axis number formatting', |
description => 'X-axis number formatting', |
edit_type => 'choice', |
edit_type => 'choice', |
choices => ['on', 'off', '2e', '2f'], |
choices => ['on', 'off', '2e', '2f'], |
}, |
}, |
yformat => { |
yformat => { |
default => 'on', |
default => 'on', |
test => sub {$_[0]=~/^(on|off|\d+(f|F|e|E))$/}, |
test => sub {$_[0]=~/^(on|off|\d+(f|F|e|E|P(|\s*\Q\0317\0200\E)))$/}, |
description => 'X-axis number formatting', |
description => 'Y-axis number formatting', |
edit_type => 'choice', |
edit_type => 'choice', |
choices => ['on', 'off', '2e', '2f'], |
choices => ['on', 'off', '2e', '2f'], |
}, |
}, |
|
|
|
xzero => { |
|
default => 'off', |
|
test => sub {$_[0]=~/^(off|line|thick-line|dotted)$/}, |
|
description => 'Show x-zero (y=0) axis', |
|
edit_type => 'choice', |
|
choices => ['off', 'line', 'thick-line', 'dotted'], |
|
}, |
|
|
|
yzero => { |
|
default => 'off', |
|
test => sub {$_[0]=~/^(off|line|thick-line|dotted)$/}, |
|
description => 'Show y-zero (x=0) axis', |
|
edit_type => 'choice', |
|
choices => ['off', 'line', 'thick-line', 'dotted'], |
|
}, |
); |
); |
|
|
my @curve_edit_order = ('color','name','linestyle','linewidth','linetype','pointtype','pointsize','limit'); |
|
|
my @curve_edit_order = ('color','name','linestyle','linewidth','linetype', |
|
'pointtype','pointsize','limit', 'arrowhead', 'arrowstyle', |
|
'arrowlength', 'arrowangle', 'arrowbackangle' |
|
); |
|
|
my %curve_defaults = |
my %curve_defaults = |
( |
( |
color => { |
color => { |
default => 'x000000', |
default => $colorprefix.'000000', |
test => $color_test, |
test => $color_test, |
description => 'Color of curve (x000000)', |
description => 'Color of curve ('.$colorprefix.'000000)', |
edit_type => 'entry', |
edit_type => 'entry', |
size => '10' |
size => '10', |
|
class => 'colorchooser' |
}, |
}, |
name => { |
name => { |
default => '', |
default => '', |
Line 563 my %curve_defaults =
|
Line 624 my %curve_defaults =
|
edit_type => 'choice', |
edit_type => 'choice', |
choices => ['above', 'below', 'closed','x1','x2','y1','y2'] |
choices => ['above', 'below', 'closed','x1','x2','y1','y2'] |
}, |
}, |
|
arrowhead => { |
|
default => 'head', |
|
test => $arrowhead_test, |
|
description => 'Vector arrow head type', |
|
edit_type => 'choice', |
|
choices => ['nohead', 'head', 'heads'] |
|
}, |
|
arrowstyle => { |
|
default => 'filled', |
|
test => $arrowstyle_test, |
|
description => 'Vector arrow head style', |
|
edit_type => 'choice', |
|
choices => ['filled', 'empty', 'nofilled'] |
|
}, |
|
arrowlength => { |
|
default => 0.02, |
|
test => $pos_real_test, |
|
description => "Length of vector arrow (only applies to vector plots)", |
|
edit_type => 'entry', |
|
size => '5' |
|
}, |
|
arrowangle => { |
|
default => 10.0, |
|
test => $degree_test, |
|
description => 'Angle of arrow branches to arrow body (only applies to vector plots)', |
|
edit_type => 'entry', |
|
size => '5' |
|
}, |
|
|
|
arrowbackangle => { |
|
default => 90.0, |
|
test => $degree_test, |
|
descripton => 'Angle of arrow back lines to branches.', |
|
edit_type => 'entry', |
|
size => '5' |
|
} |
|
|
); |
); |
|
|
################################################################### |
################################################################### |
Line 574 my %curve_defaults =
|
Line 672 my %curve_defaults =
|
undef %Apache::lonplot::plot; |
undef %Apache::lonplot::plot; |
my (%key,%axis,$title,$xlabel,$ylabel,@labels,@curves,%xtics,%ytics); |
my (%key,%axis,$title,$xlabel,$ylabel,@labels,@curves,%xtics,%ytics); |
|
|
|
my $current_tics; # Reference to the current tick hash |
|
|
sub start_gnuplot { |
sub start_gnuplot { |
undef(%Apache::lonplot::plot); undef(%key); undef(%axis); |
undef(%Apache::lonplot::plot); undef(%key); undef(%axis); |
undef($title); undef($xlabel); undef($ylabel); |
undef($title); undef($xlabel); undef($ylabel); |
Line 598 sub start_gnuplot {
|
Line 698 sub start_gnuplot {
|
} elsif ($target eq 'modified') { |
} elsif ($target eq 'modified') { |
my $constructtag=&Apache::edit::get_new_args |
my $constructtag=&Apache::edit::get_new_args |
($token,$parstack,$safeeval,keys(%gnuplot_defaults)); |
($token,$parstack,$safeeval,keys(%gnuplot_defaults)); |
|
|
if ($constructtag) { |
if ($constructtag) { |
|
# |
|
# Color chooser does not prepend x (or #) to the color values |
|
# Do that here: |
|
# |
|
foreach my $attribute ('bgcolor', 'fgcolor') { |
|
my $value = $token->[2]{$attribute}; |
|
if (defined $value && ($value !~ /^\Q$colorprefix\E/)) { |
|
$token->[2]{$attribute} = $colorprefix . $value; |
|
} |
|
} |
$result = &Apache::edit::rebuild_tag($token); |
$result = &Apache::edit::rebuild_tag($token); |
} |
} |
} |
} |
Line 612 sub end_gnuplot {
|
Line 723 sub end_gnuplot {
|
('title','xlabel','ylabel','key','axis','label','curve')); |
('title','xlabel','ylabel','key','axis','label','curve')); |
my $result = ''; |
my $result = ''; |
my $randnumber; |
my $randnumber; |
|
my $tmpdir =LONCAPA::tempdir(); # Where temporary files live: |
|
|
# need to call rand everytime start_script would evaluate, as the |
# need to call rand everytime start_script would evaluate, as the |
# safe space rand number generator and the global rand generator |
# safe space rand number generator and the global rand generator |
# are not separate |
# are not separate |
Line 623 sub end_gnuplot {
|
Line 736 sub end_gnuplot {
|
&check_inputs(); # Make sure we have all the data we need |
&check_inputs(); # Make sure we have all the data we need |
## |
## |
## Determine filename |
## Determine filename |
my $tmpdir = '/home/httpd/perl/tmp/'; |
|
my $filename = $env{'user.name'}.'_'.$env{'user.domain'}. |
my $filename = $env{'user.name'}.'_'.$env{'user.domain'}. |
'_'.time.'_'.$$.$randnumber.'_plot'; |
'_'.time.'_'.$$.$randnumber.'_plot'; |
## Write the plot description to the file |
## Write the plot description to the file |
Line 631 sub end_gnuplot {
|
Line 743 sub end_gnuplot {
|
$filename = &escape($filename); |
$filename = &escape($filename); |
## return image tag for the plot |
## return image tag for the plot |
if ($target eq 'web') { |
if ($target eq 'web') { |
$result .= <<"ENDIMAGE"; |
my $srcatt = "src=\"/cgi-bin/plot.$weboutputformat?file=$filename.data\""; |
<img src = "/cgi-bin/plot.$weboutputformat?file=$filename.data" |
my $widthatt = "width=\"$Apache::lonplot::plot{'width'}\""; |
width = "$Apache::lonplot::plot{'width'}" |
my $heightatt = "height=\"$Apache::lonplot::plot{'height'}\""; |
height = "$Apache::lonplot::plot{'height'}" |
my $alignatt = "align=\"$Apache::lonplot::plot{'align'}\""; |
align = "$Apache::lonplot::plot{'align'}" |
my $altatt = "alt=\"$Apache::lonplot::plot{'alttag'}\""; |
alt = "$Apache::lonplot::plot{'alttag'}" /> |
if ($Apache::lonplot::plot{'align'} eq 'center') { |
ENDIMAGE |
$result .= '<div style="text-align:center">'. |
|
"<img $srcatt $widthatt $heightatt $altatt>". |
|
"</div>\n"; |
|
|
|
} else { |
|
$result .= "<img $srcatt $widthatt $heightatt $alignatt $altatt>"; |
|
} |
} elsif ($target eq 'tex') { |
} elsif ($target eq 'tex') { |
&Apache::lonxml::debug(" gnuplot wid = $Apache::lonplot::plot{'width'}"); |
&Apache::lonxml::debug(" gnuplot wid = $Apache::lonplot::plot{'width'}"); |
&Apache::lonxml::debug(" gnuplot ht = $Apache::lonplot::plot{'height'}"); |
&Apache::lonxml::debug(" gnuplot ht = $Apache::lonplot::plot{'height'}"); |
#might be inside the safe space, register the URL for later |
#might be inside the safe space, register the URL for later |
&Apache::lonxml::register_ssi("/cgi-bin/plot.gif?file=$filename.data&output=eps"); |
&Apache::lonxml::register_ssi("/cgi-bin/plot.gif?file=$filename.data&output=eps"); |
$result = "%DYNAMICIMAGE:$Apache::lonplot::plot{'width'}:$Apache::lonplot::plot{'height'}:$Apache::lonplot::plot{'texwidth'}\n"; |
$result = "%DYNAMICIMAGE:$Apache::lonplot::plot{'width'}:$Apache::lonplot::plot{'height'}:$Apache::lonplot::plot{'texwidth'}\n"; |
$result .= '\graphicspath{{/home/httpd/perl/tmp/}}'."\n"; |
$result .= '\graphicspath{{'.$tmpdir.'}}'."\n"; |
|
if ($Apache::lonplot::plot{'align'} eq 'center') { |
|
$result .= '\begin{center}'; |
|
} |
$result .= '\includegraphics[width='.$Apache::lonplot::plot{'texwidth'}.' mm]{'.&unescape($filename).'.eps}'; |
$result .= '\includegraphics[width='.$Apache::lonplot::plot{'texwidth'}.' mm]{'.&unescape($filename).'.eps}'; |
|
if ($Apache::lonplot::plot{'align'} eq 'center') { |
|
$result .= '\end{center}'; |
|
} |
} |
} |
} elsif ($target eq 'edit') { |
} elsif ($target eq 'edit') { |
$result.=&Apache::edit::tag_end($target,$token); |
$result.=&Apache::edit::tag_end($target,$token); |
Line 661 sub start_xtics {
|
Line 785 sub start_xtics {
|
if ($target eq 'web' || $target eq 'tex') { |
if ($target eq 'web' || $target eq 'tex') { |
&get_attributes(\%xtics,\%tic_defaults,$parstack,$safeeval, |
&get_attributes(\%xtics,\%tic_defaults,$parstack,$safeeval, |
$tagstack->[-1]); |
$tagstack->[-1]); |
|
$current_tics = \%xtics; |
|
&Apache::lonxml::register('Apache::lonplot', 'tic'); |
} elsif ($target eq 'edit') { |
} elsif ($target eq 'edit') { |
$result .= &Apache::edit::tag_start($target,$token,'xtics'); |
$result .= &Apache::edit::tag_start($target,$token,'xtics'); |
$result .= &edit_attributes($target,$token,\%tic_defaults, |
$result .= &edit_attributes($target,$token,\%tic_defaults, |
Line 679 sub end_xtics {
|
Line 805 sub end_xtics {
|
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my $result = ''; |
my $result = ''; |
if ($target eq 'web' || $target eq 'tex') { |
if ($target eq 'web' || $target eq 'tex') { |
|
&Apache::lonxml::deregister('Apache::lonplot', 'tic'); |
} elsif ($target eq 'edit') { |
} elsif ($target eq 'edit') { |
$result.=&Apache::edit::tag_end($target,$token); |
$result.=&Apache::edit::tag_end($target,$token); |
} |
} |
Line 692 sub start_ytics {
|
Line 819 sub start_ytics {
|
if ($target eq 'web' || $target eq 'tex') { |
if ($target eq 'web' || $target eq 'tex') { |
&get_attributes(\%ytics,\%tic_defaults,$parstack,$safeeval, |
&get_attributes(\%ytics,\%tic_defaults,$parstack,$safeeval, |
$tagstack->[-1]); |
$tagstack->[-1]); |
|
$current_tics = \%ytics; |
|
&Apache::lonxml::register('Apache::lonplot', 'tic'); |
} elsif ($target eq 'edit') { |
} elsif ($target eq 'edit') { |
$result .= &Apache::edit::tag_start($target,$token,'ytics'); |
$result .= &Apache::edit::tag_start($target,$token,'ytics'); |
$result .= &edit_attributes($target,$token,\%tic_defaults, |
$result .= &edit_attributes($target,$token,\%tic_defaults, |
Line 710 sub end_ytics {
|
Line 839 sub end_ytics {
|
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my $result = ''; |
my $result = ''; |
if ($target eq 'web' || $target eq 'tex') { |
if ($target eq 'web' || $target eq 'tex') { |
|
&Apache::lonxml::deregister('Apache::lonplot', 'tic'); |
} elsif ($target eq 'edit') { |
} elsif ($target eq 'edit') { |
$result.=&Apache::edit::tag_end($target,$token); |
$result.=&Apache::edit::tag_end($target,$token); |
} |
} |
return $result; |
return $result; |
} |
} |
|
|
|
|
|
##---------------------------------------------------------------- |
|
# |
|
# Tic handling: |
|
# The <tic> tag allows users to specify exact Tic positions and labels |
|
# for each axis. In this version we only support level 0 tics (major tic). |
|
# Each tic has associated with it a position and a label |
|
# $current_tics is a reference to the current tick description hash. |
|
# We add elements to an array in that has: ticspecs whose elements |
|
# are 'pos' - the tick position and 'label' - the tic label. |
|
# |
|
|
|
|
|
sub start_tic { |
|
my ($target, $token, $tagstack, $parstack, $parser, $safeeval, $style) = @_; |
|
|
|
my $result = ''; |
|
if ($target eq 'web' || $target eq 'tex') { |
|
my $tic_location = &Apache::lonxml::get_param('location', $parstack, $safeeval); |
|
my $tic_label = &Apache::lonxml::get_all_text('/tic', $parser); |
|
|
|
# Tic location must e a real: |
|
|
|
if (!&$real_test($tic_location)) { |
|
&Apache::lonxml::warning("Tic location: $tic_location must be a real number"); |
|
} else { |
|
|
|
if (!defined $current_tics->{'ticspecs'}) { |
|
$current_tics->{'ticspecs'} = []; |
|
} |
|
my $ticspecs = $current_tics->{'ticspecs'}; |
|
push (@$ticspecs, {'pos' => $tic_location, 'label' => $tic_label}); |
|
} |
|
} |
|
|
|
return $result; |
|
} |
|
|
|
sub end_tic { |
|
return ''; |
|
} |
|
|
##-----------------------------------------------------------------font |
##-----------------------------------------------------------------font |
my %font_properties = |
my %font_properties = |
( |
( |
Line 757 sub get_font {
|
Line 929 sub get_font {
|
$selected_font = $font_properties{$Apache::lonplot::plot{'fontface'}}; |
$selected_font = $font_properties{$Apache::lonplot::plot{'fontface'}}; |
} |
} |
if ($target eq 'tex' && defined($Apache::lonplot::plot{'texfont'})) { |
if ($target eq 'tex' && defined($Apache::lonplot::plot{'texfont'})) { |
|
# $selected_font = $font_properties{'classic'}; |
$size = $Apache::lonplot::plot{'texfont'}; |
$size = $Apache::lonplot::plot{'texfont'}; |
} |
} |
return ($size, $selected_font); |
return ($size, $selected_font); |
Line 819 sub parse_label {
|
Line 992 sub parse_label {
|
return $result; |
return $result; |
} |
} |
|
|
|
# |
|
# Note that there are severe restrictions on font selection in the |
|
# ps driver now. later in life Gnuplot is supposed to support |
|
# utf-8 fonts in the posts script driver. When this happens, |
|
# the tex entries with comments that include the word <FIX> |
|
# should be changed to print the correct glyphs rather than some |
|
# approximation or fallback of what is intended. |
|
|
my %lookup = |
my %lookup = |
( # Greek alphabet: |
( # Greek alphabet: |
Line 888 my %lookup =
|
Line 1068 my %lookup =
|
'#134' => {'tex' => '{/Text \262}', 'web' => "\x{2020}"}, |
'#134' => {'tex' => '{/Text \262}', 'web' => "\x{2020}"}, |
'#135' => {'tex' => '{/Text \263}', 'web' => "\x{2021}"}, |
'#135' => {'tex' => '{/Text \263}', 'web' => "\x{2021}"}, |
'#136' => {'tex' => '\\\\^', 'web' => '\\\\^'}, |
'#136' => {'tex' => '\\\\^', 'web' => '\\\\^'}, |
'#137' => {'tex' => '{/Text \275}', 'web' => "\x{2030}"}, |
'#137' => {'tex' => '%o', 'web' => "\x{2030}"}, # Per Mille <FIX> |
'#138' => {'tex' => 'S', 'web' => "\x{160}"}, # no S-caron in ps fonts. |
'#138' => {'tex' => 'S', 'web' => "\x{160}"}, # S-Caron <FIX> |
'#139' => {'tex' => '<', 'web' => '<'}, |
'#139' => {'tex' => '<', 'web' => '<'}, |
'#140' => {'tex' => '{/Text \352}', 'web' => "\x{152}"}, |
'#140' => {'tex' => 'AE', 'web' => "\x{152}"}, # AE ligature <FIX> |
'#145' => {'tex' => '\140', 'web' => "\x{2018}"}, |
'#145' => {'tex' => '\140', 'web' => "\x{2018}"}, |
'#146' => {'tex' => '\47', 'web' => "\x{2019}"}, |
'#146' => {'tex' => '\47', 'web' => "\x{2019}"}, |
'#147' => {'tex' => '{/Text \252}', 'web' => "\x{201c}"}, |
'#147' => {'tex' => '\140\140', 'web' => "\x{201c}"}, # Left " <FIX> |
'#148' => {'tex' => '{/Text \315}', 'web' => '\\"'}, |
'#148' => {'tex' => '\47\47', 'web' => '\\"'}, # Right " <FIX> |
'#149' => {'tex' => '{/Symbol \267}', 'web' => "\x{2022}"}, |
'#149' => {'tex' => '{/Symbol \267}', 'web' => "\x{2022}"}, |
'#150' => {'tex' => '{/Text \55}', 'web' => "\x{2013}"}, #Untested here en dash |
'#150' => {'tex' => '{/Text \55}', 'web' => "\x{2013}"}, # en dash |
'#151' => {'tex' => '{/Symbol \55}', 'web' => "\x{2014}"}, # em dash |
'#151' => {'tex' => '{/Symbol \55}', 'web' => "\x{2014}"}, # em dash |
'#152' => {'tex' => '~', 'web' => '~'}, |
'#152' => {'tex' => '\\\\~', 'web' => '\\\\~'}, |
'#153' => {'tex' => '{/Text \324}', 'web' => "\x{2122}"}, # trademark |
'#153' => {'tex' => '{/Symbol \324}', 'web' => "\x{2122}"}, # trademark |
|
|
# Accented letters, and other furreign language glyphs. |
# Accented letters, and other furreign language glyphs. |
|
|
'#154' => {'tex' => 's', 'web' => "\x{161}"}, # small s-caron no ps. |
'#154' => {'tex' => 's', 'web' => "\x{161}"}, # small s-caron no ps. |
'#155' => {'tex' => '>', 'web' => '\76'}, # > |
'#155' => {'tex' => '>', 'web' => '\76'}, # > |
'#156' => {'tex' => '{/Text \372}', 'web' => "\x{153}"}, # oe ligature. |
'#156' => {'tex' => '{/Text \366}', 'web' => "\x{153}"}, # oe ligature.<FIX> |
'#159', => {'tex' => 'Y', 'web' => "\x{178}"}, # Y-umlaut - can't print |
'#159', => {'tex' => 'Y', 'web' => "\x{178}"}, # Y-umlaut - can't print <FIX> |
'(nbsp|#160)' => {'tex' => ' ', 'web' => ' '}, # non breaking space. |
'(nbsp|#160)' => {'tex' => ' ', 'web' => ' '}, # non breaking space. |
'(iexcl|#161)' => {'tex' => '{/Text \241}', 'web' => "\x{a1}"}, # inverted ! |
'(iexcl|#161)' => {'tex' => '{/Text \241}', 'web' => "\x{a1}"}, # inverted ! |
'(cent|#162)' => {'tex' => '{/Text \242}', 'web' => "\x{a2}"}, # Cent currency. |
'(cent|#162)' => {'tex' => '{/Text \242}', 'web' => "\x{a2}"}, # Cent currency. |
'(pound|#163}' => {'tex' => '{/Text \243}', 'web' => "\x{a3}"}, # GB Pound currency. |
'(pound|#163)' => {'tex' => '{/Text \243}', 'web' => "\x{a3}"}, # GB Pound currency. |
'(curren|#164)' => {'tex' => '{/Text \250}', 'web' => "\x{a4}"}, # Generic currency symb. |
'(curren|#164)' => {'tex' => '{/ZapfDingbats \161}','web' => "\x{a4}"}, # Generic currency symb. <FIX> |
'(yen|#165)' => {'tex' => '{/Text \245}', 'web' => "\x{a5}"}, # Yen currency. |
'(yen|#165)' => {'tex' => '{/Text \245}', 'web' => "\x{a5}"}, # Yen currency. |
'(brvbar|#166)' => {'tex' => '{/Symbol \174}', 'web' => "\x{a6}"}, # Broken vert bar no print. |
'(brvbar|#166)' => {'tex' => '{/Symbol \174}', 'web' => "\x{a6}"}, # Broken vert bar no print. |
'(sect|#167)' => {'tex' => '{\247}', 'web' => "\x{a7}"}, # Section symbol. |
'(sect|#167)' => {'tex' => '{\247}', 'web' => "\x{a7}"}, # Section symbol. |
Line 921 my %lookup =
|
Line 1101 my %lookup =
|
'(ordf|#170)' => {'tex' => '{/Text \343}', 'web' => "\x{aa}"}, # Feminine ordinal. |
'(ordf|#170)' => {'tex' => '{/Text \343}', 'web' => "\x{aa}"}, # Feminine ordinal. |
'(laquo|#171)' => {'tex' => '{/Text \253}', 'web' => "\x{ab}"}, # << quotes. |
'(laquo|#171)' => {'tex' => '{/Text \253}', 'web' => "\x{ab}"}, # << quotes. |
'(not|#172)' => {'tex' => '\254', 'web' => "\x{ac}"}, # Logical not. |
'(not|#172)' => {'tex' => '\254', 'web' => "\x{ac}"}, # Logical not. |
'(shy|#173)' => {'tex' => '-', 'web' => "\x{ad}"}, # soft hyphen. |
'(shy|#173)' => {'tex' => '\255', 'web' => "\x{ad}"}, # soft hyphen. |
'(reg|#174)' => {'tex' => '{/Symbol \342}', 'web' => "\x{ae}"}, # Registered tm. |
'(reg|#174)' => {'tex' => '{/Symbol \342}', 'web' => "\x{ae}"}, # Registered tm. |
'(macr|#175)' => {'tex' => '^{-}', 'web' => "\x{af}"}, # 'naked' macron (overbar). |
'(macr|#175)' => {'tex' => '^{\255}', 'web' => "\x{af}"}, # 'naked' macron (overbar). |
'(deg|#176)' => {'tex' => '{/Text \312}', 'web' => "\x{b0}"}, # Degree symbo.. |
'(deg|#176)' => {'tex' => '{/Text \260}', 'web' => "\x{b0}"}, # Degree symbo..` |
'(plusmn|#177)' => {'tex' => '{/Symbol \261}', 'web' => "\x{b1}"}, # +/- symbol. |
'(plusmn|#177)' => {'tex' => '{/Symbol \261}', 'web' => "\x{b1}"}, # +/- symbol. |
'(sup2|#178)' => {'tex' => '^2', 'web' => "\x{b2}"}, # Superscript 2. |
'(sup2|#178)' => {'tex' => '^2', 'web' => "\x{b2}"}, # Superscript 2. |
'(sup3|#179)' => {'tex' => '^3', 'web' => "\x{b3}"}, # Superscript 3. |
'(sup3|#179)' => {'tex' => '^3', 'web' => "\x{b3}"}, # Superscript 3. |
'(acute|#180)' => {'tex' => '{/Text \302}', 'web' => "\x{b4}"}, # 'naked' acute accent. |
'(acute|#180)' => {'tex' => '{/Text \222}', 'web' => "\x{b4}"}, # 'naked' acute accent. |
'(micro|#181)' => {'tex' => '{/Symbol \155}', 'web' => "\x{b5}"}, # Micro (small mu). |
'(micro|#181)' => {'tex' => '{/Symbol \155}', 'web' => "\x{b5}"}, # Micro (small mu). |
'(para|#182)' => {'tex' => '{/Text \266}', 'web' => "\x{b6}"}, # Paragraph symbol. |
'(para|#182)' => {'tex' => '{/Text \266}', 'web' => "\x{b6}"}, # Paragraph symbol. |
'(middot|#183)' => {'tex' => '^.', 'web' => "\x{b7}"}, # middle dot (maybe text 267 is better)? |
'(middot|#183)' => {'tex' => '\267', 'web' => "\x{b7}"}, # middle dot |
'(cedil|#184)' => {'tex' => '\233', 'web' => "\x{b8}"}, # 'naked' cedilla. |
'(cedil|#184)' => {'tex' => '\233', 'web' => "\x{b8}"}, # 'naked' cedilla. |
'(sup1|#185)' => {'tex' => '^1', 'web' => "\x{b9}"}, # superscript 1. |
'(sup1|#185)' => {'tex' => '^1', 'web' => "\x{b9}"}, # superscript 1. |
'(ordm|#186)' => {'tex' => '\353', 'web' => "\x{ba}"}, # masculine ordinal. |
'(ordm|#186)' => {'tex' => '{\260}', 'web' => "\x{ba}"}, # masculine ordinal. |
'(raquo|#187)', => {'tex' => '\273', 'web' => "\x{bb}"}, # Right angle quotes. |
'(raquo|#187)', => {'tex' => '\273', 'web' => "\x{bb}"}, # Right angle quotes. |
'(frac14|#188)' => {'tex' => '\274', 'web' => "\x{bc}"}, # 1/4. |
'(frac14|#188)' => {'tex' => '\274', 'web' => "\x{bc}"}, # 1/4. |
'(frac12|#189)' => {'tex' => '\275', 'web' => "\x{bd}"}, # 1/2. |
'(frac12|#189)' => {'tex' => '\275', 'web' => "\x{bd}"}, # 1/2. |
Line 979 my %lookup =
|
Line 1159 my %lookup =
|
'(auml|#228)' => {'tex' => '\344', 'web' => "\x{e4}"}, # a umlaut |
'(auml|#228)' => {'tex' => '\344', 'web' => "\x{e4}"}, # a umlaut |
'(aring|#229)' => {'tex' => '\345', 'web' => "\x{e5}"}, # a ring on top. |
'(aring|#229)' => {'tex' => '\345', 'web' => "\x{e5}"}, # a ring on top. |
'(aelig|#230)' => {'tex' => '\346', 'web' => "\x{e6}"}, # ae ligature. |
'(aelig|#230)' => {'tex' => '\346', 'web' => "\x{e6}"}, # ae ligature. |
'{ccedil|#231)' => {'tex' => '\347', 'web' => "\x{e7}"}, # C cedilla |
'(ccedil|#231)' => {'tex' => '\347', 'web' => "\x{e7}"}, # C cedilla |
'(egrave|#232)' => {'tex' => '\350', 'web' => "\x{e8}"}, # e accent grave. |
'(egrave|#232)' => {'tex' => '\350', 'web' => "\x{e8}"}, # e accent grave. |
'(eacute|#233)' => {'tex' => '\351', 'web' => "\x{e9}"}, # e accent acute. |
'(eacute|#233)' => {'tex' => '\351', 'web' => "\x{e9}"}, # e accent acute. |
'(ecirc|#234)' => {'tex' => '\352', 'web' => "\x{ea}" }, # e circumflex. |
'(ecirc|#234)' => {'tex' => '\352', 'web' => "\x{ea}" }, # e circumflex. |
'(euml|#235)' => {'tex' => '\353', 'web' => "\x{eb}"}, # e umlaut. |
'(euml|#235)' => {'tex' => '\353', 'web' => "\x{eb}"}, # e umlaut. |
'(igrave|#236)' => {'tex' => '\354', 'web' => "\x{ec}"}, # i grave. |
'(igrave|#236)' => {'tex' => '\354', 'web' => "\x{ec}"}, # i grave. |
'(iacute|#237}' => {'tex' => '\355', 'web' => "\x{ed}"}, # i acute. |
'(iacute|#237)' => {'tex' => '\355', 'web' => "\x{ed}"}, # i acute. |
'(icirc|#238}' => {'tex' => '\356', 'web' => "\x{ee}"}, # i circumflex. |
'(icirc|#238)' => {'tex' => '\356', 'web' => "\x{ee}"}, # i circumflex. |
'(iuml|#239)' => {'tex' => '\357', 'web' => "\x{ef}"}, # i umlaut. |
'(iuml|#239)' => {'tex' => '\357', 'web' => "\x{ef}"}, # i umlaut. |
'(eth|#240)' => {'tex' => '\360', 'web' => "\x{f0}"}, # Icelandic eth. |
'(eth|#240)' => {'tex' => '\360', 'web' => "\x{f0}"}, # Icelandic eth. |
'(ntilde|#241)' => {'tex' => '\361', 'web' => "\x{f1}"}, # n tilde. |
'(ntilde|#241)' => {'tex' => '\361', 'web' => "\x{f1}"}, # n tilde. |
'(ograve|#242)' => {'tex' => '\362', 'web' => "\x{f2}"}, # o grave. |
'(ograve|#242)' => {'tex' => '\362', 'web' => "\x{f2}"}, # o grave. |
'(oacute|#243)' => {'tex' => '\363', 'web' => "\x{f3}"}, # o acute. |
'(oacute|#243)' => {'tex' => '\363', 'web' => "\x{f3}"}, # o acute. |
'(ocirc'|#244)' => {'tex' => '\364', 'web' => "\x{f4}"}, # o circumflex. |
'(ocirc|#244)' => {'tex' => '\364', 'web' => "\x{f4}"}, # o circumflex. |
'(otilde|#245)' => {'tex' => '\365', 'web' => "\x{f5}"}, # o tilde. |
'(otilde|#245)' => {'tex' => '\365', 'web' => "\x{f5}"}, # o tilde. |
'(ouml|#246)' => {'tex' => '\366', 'web' => "\x{f6}"}, # o umlaut. |
'(ouml|#246)' => {'tex' => '\366', 'web' => "\x{f6}"}, # o umlaut. |
'(divide|#247)' => {'tex' => '\367', 'web' => "\x{f7}"}, # division symbol |
'(divide|#247)' => {'tex' => '\367', 'web' => "\x{f7}"}, # division symbol |
Line 1007 my %lookup =
|
Line 1187 my %lookup =
|
|
|
# Latin extended A entities: |
# Latin extended A entities: |
|
|
'(OElig|#338)' => {'tex' => '{/Text \352}', 'web' => "\x{152}"}, # OE ligature. |
'(OElig|#338)' => {'tex' => '{/Text \326}', 'web' => "\x{152}"}, # OE ligature. |
'(oelig|#339)' => {'tex' => '{/Text \372}', 'web' => "\x{153}"}, # oe ligature. |
'(oelig|#339)' => {'tex' => '{/Text \366}', 'web' => "\x{153}"}, # oe ligature. |
'(Scaron|#352)' => {'tex' => 'S', 'web' => "\x{160}"}, # S caron no printable. |
'(Scaron|#352)' => {'tex' => 'S', 'web' => "\x{160}"}, # S caron no printable. |
'(scaron|#353)' => {'tex' => 's', 'web' => "\x{161}"}, # s caron no printable. |
'(scaron|#353)' => {'tex' => 's', 'web' => "\x{161}"}, # s caron no printable. |
'(Yuml|#376)' => {'tex' => 'Y', 'web' => "\x{178}"}, # Y umlaut - no printable. |
'(Yuml|#376)' => {'tex' => 'Y', 'web' => "\x{178}"}, # Y umlaut - no printable. |
|
|
# Latin extended B. |
# Latin extended B. |
|
|
'(fnof|#402)' => {'tex' =>'{/Symbol 246}', 'web' => "\x{192}"}, # f with little hook. |
'(fnof|#402)' => {'tex' =>'{/Symbol \246}', 'web' => "\x{192}"}, # f with little hook. |
|
|
# Standalone accents: |
# Standalone accents: |
|
|
Line 1030 my %lookup =
|
Line 1210 my %lookup =
|
'(ensp|#8194)' => {'tex' => ' ', 'web' => "\x{2002}"}, # en space. |
'(ensp|#8194)' => {'tex' => ' ', 'web' => "\x{2002}"}, # en space. |
'(emsp|#8195)' => {'tex' => ' ', 'web' => "\x{2003}"}, # em space. |
'(emsp|#8195)' => {'tex' => ' ', 'web' => "\x{2003}"}, # em space. |
'(thinsp|#8201)' => {'tex' => ' ', 'web' => "\x{2009}"}, # thin space. |
'(thinsp|#8201)' => {'tex' => ' ', 'web' => "\x{2009}"}, # thin space. |
'(zwnj|#8204)' => {'tex' => '', 'web' => "\x{200c}"}, # Zero width non joiner. |
'(zwnj|#8204)' => {'tex' => ' ', 'web' => "\x{200c}"}, # Zero width non joiner. |
'(zwj|#8205)' => {'tex' => '', 'web' => "\x{200d}"}, # Zero width joiner. |
'(zwj|#8205)' => {'tex' => ' ', 'web' => "\x{200d}"}, # Zero width joiner. |
'(lrm|#8206)' => {'tex' => '', 'web' => "\x{200e}"}, # Left to right mark |
'(lrm|#8206)' => {'tex' => ' ', 'web' => "\x{200e}"}, # Left to right mark |
'(rlm|#8207)' => {'tex' => '', 'web' => "\x{200f}"}, # right to left mark. |
'(rlm|#8207)' => {'tex' => ' ', 'web' => "\x{200f}"}, # right to left mark. |
'(ndash|#8211)' => {'tex' => '{/Text \55}', 'web' => "\x{2013}"}, # en dash. |
'(ndash|#8211)' => {'tex' => '{/Text \55}', 'web' => "\x{2013}"}, # en dash. |
'(mdash|#8212)' => {'tex' => '{/Symbol \55}', 'web' => "\x{2014}"}, # em dash. |
'(mdash|#8212)' => {'tex' => '{/Symbol \55}', 'web' => "\x{2014}"}, # em dash. |
'(lsquo|#8216)' => {'tex' => '{/Text \140}', 'web' => "\x{2018}"}, # Left single quote. |
'(lsquo|#8216)' => {'tex' => '{/Text \140}', 'web' => "\x{2018}"}, # Left single quote. |
'(rsquo|#8217)' => {'tex' => '{/Symbol \242}', 'web' => "\x{2019}"}, # Right single quote. |
'(rsquo|#8217)' => {'tex' => '\47', 'web' => "\x{2019}"}, # Right single quote. |
'(sbquo|#8218)' => {'tex' => ',', 'web' => "\x{201a}"}, # Single low-9 quote. |
'(sbquo|#8218)' => {'tex' => '\54', 'web' => "\x{201a}"}, # Single low-9 quote. |
'(ldquo|#8220)' => {'tex' => '{/Text \252}', 'web' => "\x{201c}"}, # Left double quote. |
'(ldquo|#8220)' => {'tex' => '\42', 'web' => "\x{201c}"}, # Left double quote. |
'(rdquo|#8221)' => {'tex' => '{/Text \272}', 'web' => "\x{201d}"}, # Right double quote. |
'(rdquo|#8221)' => {'tex' => '\42', 'web' => "\x{201d}"}, # Right double quote. |
'(bdquo|#8222)' => {'tex' => '{/Text \271}', 'web' => "\x{201e}"}, # Double low-9 quote. |
'(bdquo|#8222)' => {'tex' => ',', 'web' => "\x{201e}"}, # Double low-9 quote. |
'(dagger|#8224)' => {'tex' => '{/Text \262}', 'web' => "\x{2020}"}, # Is this a dagger I see before me now? |
'(dagger|#8224)' => {'tex' => '+', 'web' => "\x{2020}"}, # Is this a dagger I see before me now? |
'(Dagger|#8225)' => {'tex' => '{/Text \263}', 'web' => "\x{2021}"}, # it's handle pointing towards my heart? |
'(Dagger|#8225)' => {'tex' => '\261', 'web' => "\x{2021}"}, # it's handle pointing towards my heart? |
'(bull|#8226)' => {'tex' => '\267', 'web' => "\x{2022}"}, # Bullet. |
'(bull|#8226)' => {'tex' => '\267', 'web' => "\x{2022}"}, # Bullet. |
'(hellep|#8230)' => {'tex' => '{/Text \274}', 'web' => "\x{2026}"}, # Ellipses. |
'(hellep|#8230)' => {'tex' => '{/Symbol \274}', 'web' => "\x{2026}"}, # Ellipses. |
'(permil|#8240)' => {'tex' => '{/Text \275}', 'web' => "\x{2031}"}, # Per mille. |
'(permil|#8240)' => {'tex' => '%_o', 'web' => "\x{2031}"}, # Per mille. |
'(prime|#8242)' => {'tex' => '\264', 'web' => "\x{2032}"}, # Prime. |
'(prime|#8242)' => {'tex' => '\264', 'web' => "\x{2032}"}, # Prime. |
'(Prime|#8243)' => {'tex' => '{/Symbol \262}', 'web' => "\x{2033}"}, # double prime. |
'(Prime|#8243)' => {'tex' => '{/Symbol \262}', 'web' => "\x{2033}"}, # double prime. |
'(lsaquo|#8249)' => {'tex' => '{/Text \254}', 'web' => "\x{2039}"}, # < quote. |
'(lsaquo|#8249)' => {'tex' => '<', 'web' => "\x{2039}"}, # < quote. |
'(rsaquo|#8250)' => {'tex' => '{/Text \255}', 'web' => "\x{2040}"}, # > quote. |
'(rsaquo|#8250)' => {'tex' => '\74', 'web' => "\x{203a}"}, # > quote. |
'(oline|#8254)' => {'tex' => '{/Symbol \140}', 'web' => "\x{203e}"}, # Overline. |
'(oline|#8254)' => {'tex' => '{/Symbol \140}', 'web' => "\x{203e}"}, # Overline. |
'(frasl|#8260)' => {'tex' => '/', 'web' => "\x{2044}"}, # Fraction slash. |
'(frasl|#8260)' => {'tex' => '/', 'web' => "\x{2044}"}, # Fraction slash. |
'(euro|#8364)' => {'tex' => '{/Symbol \240}', 'web' => "\x{20a0}"}, # Euro currency. |
'(euro|#8364)' => {'tex' => '{/Symbol \240}', 'web' => "\x{20ac}"}, # Euro currency. |
|
|
# Letter like symbols. |
# Letter like symbols. |
|
|
Line 1065 my %lookup =
|
Line 1245 my %lookup =
|
|
|
# Arrows of various types and directions. |
# Arrows of various types and directions. |
'(larr|#8592)' => {'tex' => '{/Symbol \254}', 'web' => "\x{2190}"}, # <-- |
'(larr|#8592)' => {'tex' => '{/Symbol \254}', 'web' => "\x{2190}"}, # <-- |
'(uarr|#8593}' => {'tex' => '{/Symbol \255}', 'web' => "\x{2191}"}, # up arrow. |
'(uarr|#8593)' => {'tex' => '{/Symbol \255}', 'web' => "\x{2191}"}, # up arrow. |
'(rarr|#8594)' => {'tex' => '{/Symbol \256}', 'web' => "\x{2192}"}, # --> |
'(rarr|#8594)' => {'tex' => '{/Symbol \256}', 'web' => "\x{2192}"}, # --> |
'(darr|#8595)' => {'tex' => '{/Symbol \257}', 'web' => "\x{2193}"}, # down arrow. |
'(darr|#8595)' => {'tex' => '{/Symbol \257}', 'web' => "\x{2193}"}, # down arrow. |
'(harr|#8596)' => {'tex' => '{/Symbol \253}', 'web' => "\x{2194}"}, # <--> |
'(harr|#8596)' => {'tex' => '{/Symbol \253}', 'web' => "\x{2194}"}, # <--> |
Line 1084 my %lookup =
|
Line 1264 my %lookup =
|
'(empty|#8709)' => {'tex' => '{/Symbol \306}', 'web' => "\x{2205}"}, # Null set. |
'(empty|#8709)' => {'tex' => '{/Symbol \306}', 'web' => "\x{2205}"}, # Null set. |
'(nabla|#8711)' => {'tex' => '{/Symbol \321}', 'web' => "\x{2207}"}, # Gradient e.g. |
'(nabla|#8711)' => {'tex' => '{/Symbol \321}', 'web' => "\x{2207}"}, # Gradient e.g. |
'(isin|#8712)' => {'tex' => '{/Symbol \316}', 'web' => "\x{2208}"}, # Element of the set. |
'(isin|#8712)' => {'tex' => '{/Symbol \316}', 'web' => "\x{2208}"}, # Element of the set. |
|
'(notin|#8713)' => {'tex' => '{/Symbol \317}', 'web' => "\x{2209}"}, # Not an element of |
'(ni|#8715)' => {'tex' => '{/Symbol \47}', 'web' => "\x{220b}"}, # Contains as a member |
'(ni|#8715)' => {'tex' => '{/Symbol \47}', 'web' => "\x{220b}"}, # Contains as a member |
'(prod|#8719)' => {'tex' => '{/Symbol \325}', 'web' => "\x{220f}"}, # Product |
'(prod|#8719)' => {'tex' => '{/Symbol \325}', 'web' => "\x{220f}"}, # Product |
'(sum|#8721)' => {'tex' => '{/Symbol \345}', 'web' => "\x{2211}"}, # Sum of. |
'(sum|#8721)' => {'tex' => '{/Symbol \345}', 'web' => "\x{2211}"}, # Sum of. |
'(minus|#8722)' => {'tex' => '-', 'web' => "\x{2212}"}, # - sign. |
'(minus|#8722)' => {'tex' => '{/Symbol \55}', 'web' => "\x{2212}"}, # - sign. |
'(lowast|#8727)' => {'tex' => '*', 'web' => "\x{2217}"}, # * |
'(lowast|#8727)' => {'tex' => '*', 'web' => "\x{2217}"}, # * |
'(radic|#8730)' => {'tex' => '{/Symbol \326}', 'web' => "\x{221a}"}, # Square root. |
'(radic|#8730)' => {'tex' => '{/Symbol \326}', 'web' => "\x{221a}"}, # Square root. |
'(prop|#8733)' => {'tex' => '{/Symbol \265}', 'web' => "\x{221d}"}, # Proportional to. |
'(prop|#8733)' => {'tex' => '{/Symbol \265}', 'web' => "\x{221d}"}, # Proportional to. |
Line 1098 my %lookup =
|
Line 1279 my %lookup =
|
'(cap|#8745)' => {'tex' => '{/Symbol \307}', 'web' => "\x{2229}"}, # Set intersection. |
'(cap|#8745)' => {'tex' => '{/Symbol \307}', 'web' => "\x{2229}"}, # Set intersection. |
'(cup|#8746)' => {'tex' => '{/Symbol \310}', 'web' => "\x{222a}"}, # Set union. |
'(cup|#8746)' => {'tex' => '{/Symbol \310}', 'web' => "\x{222a}"}, # Set union. |
'(int|8747)' => {'tex' => '{/Symbol \362}', 'web' => "\x{222b}"}, # Integral. |
'(int|8747)' => {'tex' => '{/Symbol \362}', 'web' => "\x{222b}"}, # Integral. |
'(there4|#8756)' => {'tex' => '{/Symbol \134}', 'web' => "\x{2234}"}, # Therefore triple dots. |
|
'(sim|#8764)' => {'tex' => '~', 'web' => "\x{223c}"}, # Simlar to. |
# Some gnuplot guru will have to explain to me why the next three |
'(cong|#8773)' => {'tex' => '{/Symbol \100}', 'web' => "\x{2245}"}, # Congruent to/with. |
# require the extra slashes... else they print very funkily. |
|
|
|
'(there4|#8756)' => {'tex' => '{/Symbol \\\134}', 'web' => "\x{2234}"}, # Therefore triple dots. |
|
'(sim|#8764)' => {'tex' => '\\\176', 'web' => "\x{223c}"}, # Simlar to. |
|
'(cong|#8773)' => {'tex' => '{/Symbol \\\100}','web' => "\x{2245}"}, # Congruent to/with. |
|
|
|
'(asymp|#8776)' => {'tex' => '{/Symbol \273}', 'web' => "\x{2248}"}, # Asymptotic to. |
|
'(ne|#8800)' => {'tex' => '{/Symbol \271}', 'web' => "\x{2260}"}, # not equal to. |
|
'(equiv|#8801)' => {'tex' => '{/Symbol \272}', 'web' => "\x{2261}"}, # Equivalent to. |
|
'(le|8804)' => {'tex' => '{/Symbol \243}', 'web' => "\x{2264}"}, # Less than or equal to. |
|
'(ge|8805)' => {'tex' => '{/Symbol \263}', 'web' => "\x{2265}"}, # Greater than or equal to |
|
'(sub|8834)' => {'tex' => '{/Symbol \314}', 'web' => "\x{2282}"}, # Subset of. |
|
'(sup|8835)' => {'tex' => '{/Symbol \311}', 'web' => "\x{2283}"}, # Super set of. |
|
'(nsub|8836)' => {'tex' => '{/Symbol \313}', 'web' => "\x{2284}"}, # not subset of. |
|
'(sube|8838)' => {'tex' => '{/Symbol \315}', 'web' => "\x{2286}"}, # Subset or equal. |
|
'(supe|8839)' => {'tex' => '{/Symbol \312}', 'web' => "\x{2287}"}, # Superset or equal |
|
'(oplus|8853)' => {'tex' => '{/Symbol \305}', 'web' => "\x{2295}"}, # O with plus inside |
|
'(otimes|8855)' => {'tex' => '{/Symbol \304}', 'web' => "\x{2297}"}, # O with times. |
|
'(perp|8869)' => {'tex' => '{/Symbol \136}', 'web' => "\x{22a5}"}, # Perpendicular. |
|
'(sdot|8901)' => {'tex' => '{/Symbol \227}', 'web' => "\x{22c5}"}, # Dot operator. |
|
|
|
# Misc. technical symbols: |
|
|
|
'(lceil|8698)' => {'tex' => '{/Symbol \351}', 'web' => "\x{2308}"}, # Left ceiling. |
|
'(rceil|8969)' => {'tex' => '{/Symbol \371}', 'web' => "\x{2309}"}, # Right ceiling. |
|
'(lfloor|8970)' => {'tex' => '{/Symbol \353}', 'web' => "\x{230a}"}, # Left floor. |
|
'(rfloor|8971)' => {'tex' => '{/Symbol \373}', 'web' => "\x{230b}"}, # Right floor. |
|
|
|
# The gnuplot png font evidently does not have the big angle brackets at |
|
# positions 0x2329, 0x232a so use ordinary brackets. |
|
|
|
'(lang|9001)' => {'tex' => '{/Symbol \341}', 'web' => '<'}, # Left angle bracket. |
|
'(rang|9002)' => {'tex' => '{/Symbol \361}', 'web' => '>'}, # Right angle bracket. |
|
|
|
# Gemoetric shapes. |
|
|
|
'(loz|9674)' => {'tex' => '{/Symbol \340}', 'web' => "\x{25ca}"}, # Lozenge. |
|
|
|
# Misc. symbols |
|
|
|
'(spades|9824)' => {'tex' => '{/Symbol \252}', 'web' => "\x{2660}"}, |
|
'(clubs|9827)' => {'tex' => '{/Symbol \247}', 'web' => "\x{2663}"}, |
|
'(hearts|9829)' => {'tex' => '{/Symbol \251}', 'web' => "\x{2665}"}, |
|
'(diams|9830)' => {'tex' => '{/Symbol \250}', 'web' => "\x{2666}"} |
|
|
); |
); |
|
|
Line 1277 sub start_curve {
|
Line 1500 sub start_curve {
|
my $constructtag=&Apache::edit::get_new_args |
my $constructtag=&Apache::edit::get_new_args |
($token,$parstack,$safeeval,keys(%curve_defaults)); |
($token,$parstack,$safeeval,keys(%curve_defaults)); |
if ($constructtag) { |
if ($constructtag) { |
|
# |
|
# Fix up the color attribute as jcolor does not prepend an x |
|
# (or #) |
|
# |
|
my $value = $token->[2]{'color'}; |
|
if (defined $value && ($value !~ /^\Q$colorprefix\E/)) { |
|
$token->[2]{'color'} = $colorprefix . $value; |
|
} |
$result = &Apache::edit::rebuild_tag($token); |
$result = &Apache::edit::rebuild_tag($token); |
} |
} |
} |
} |
Line 1311 sub start_function {
|
Line 1542 sub start_function {
|
my $function = &Apache::lonxml::get_all_text("/function",$parser, |
my $function = &Apache::lonxml::get_all_text("/function",$parser, |
$style); |
$style); |
$function = &Apache::run::evaluate($function,$safeeval,$$parstack[-1]); |
$function = &Apache::run::evaluate($function,$safeeval,$$parstack[-1]); |
|
$function=~s/\^/\*\*/gs; |
|
$function=~ s/^\s+//; # Trim leading |
|
$function=~ s/\s+$//; # And trailing whitespace. |
$curves[-1]->{'function'} = $function; |
$curves[-1]->{'function'} = $function; |
} elsif ($target eq 'edit') { |
} elsif ($target eq 'edit') { |
$result .= &Apache::edit::tag_start($target,$token,'Gnuplot compatible curve function'); |
$result .= &Apache::edit::tag_start($target,$token,'Gnuplot compatible curve function'); |
Line 1381 sub start_data {
|
Line 1615 sub start_data {
|
} |
} |
# complain if the number of data points is not the same as |
# complain if the number of data points is not the same as |
# in previous sets of data. |
# in previous sets of data. |
if (($curves[-1]->{'data'}) && ($#data != $#{@{$curves[-1]->{'data'}->[0]}})){ |
if (($curves[-1]->{'data'}) && ($#data != $#{$curves[-1]->{'data'}->[0]})){ |
&Apache::lonxml::warning |
&Apache::lonxml::warning |
('Number of data points is not consistent with previous '. |
('Number of data points is not consistent with previous '. |
'number of data points'); |
'number of data points'); |
Line 1422 sub start_axis {
|
Line 1656 sub start_axis {
|
} elsif ($target eq 'modified') { |
} elsif ($target eq 'modified') { |
my $constructtag=&Apache::edit::get_new_args |
my $constructtag=&Apache::edit::get_new_args |
($token,$parstack,$safeeval,keys(%axis_defaults)); |
($token,$parstack,$safeeval,keys(%axis_defaults)); |
|
|
if ($constructtag) { |
if ($constructtag) { |
|
# |
|
# Fix up the color attribute since jchooser does not |
|
# prepend an x (or #) to the color: |
|
# |
|
my $value = $token->[2]{'color'}; |
|
if (defined $value && ($value !~ /^\Q$colorprefix\E/)) { |
|
$token->[2]{'color'} = $colorprefix . $value; |
|
} |
|
|
$result = &Apache::edit::rebuild_tag($token); |
$result = &Apache::edit::rebuild_tag($token); |
} |
} |
} |
} |
Line 1480 sub get_attributes{
|
Line 1724 sub get_attributes{
|
} |
} |
return ; |
return ; |
} |
} |
|
## |
|
# Generate tic mark specifications. |
|
# |
|
# @param type - type of tics (xtics or ytics). |
|
# @param spec - Reference to a hash that contains the tic specification. |
|
# @param target - 'tex' if hard copy target. |
|
# |
|
# @return string - the tic specification command. |
|
# |
|
sub generate_tics { |
|
my ($type, $spec, $target) = @_; |
|
my $result = ''; |
|
|
|
|
|
if ((ref($spec) eq 'HASH') && (keys(%{$spec}) > 0)) { |
|
|
|
|
|
|
|
# Major tics: - If there are 'ticspecs' these override any other |
|
# specifications: |
|
|
|
|
|
|
|
$result .= "set $type $spec->{'location'} "; |
|
$result .= ($spec->{'mirror'} eq 'on') ? 'mirror ' : 'nomirror '; |
|
if ($spec->{'rotate'} eq 'on') { |
|
$result .= ' rotate '; |
|
} |
|
if (defined $spec->{'ticspecs'}) { |
|
$result .= '( '; |
|
my @ticspecs; |
|
my $ticinfo = $spec->{'ticspecs'}; |
|
foreach my $tic (@$ticinfo) { |
|
push(@ticspecs, '"' . $tic->{'label'} . '" ' . $tic->{'pos'} ); |
|
} |
|
$result .= join(', ', (@ticspecs)); |
|
$result .= ' )'; |
|
} else { |
|
$result .= "$spec->{'start'}, "; |
|
$result .= "$spec->{'increment'}, "; |
|
$result .= "$spec->{'end'} "; |
|
} |
|
if ($target eq 'tex' ) { |
|
$result .= 'font "Helvetica,22"'; |
|
} |
|
$result .= "\n"; |
|
|
|
# minor frequency: |
|
|
|
if ($spec->{'minorfreq'} != 0) { |
|
$result .= "set m$type $spec->{'minorfreq'}\n"; |
|
} |
|
} elsif ($target eq 'tex' ) { |
|
$result .= "set $type font " . '"Helvetica,22"' ."\n"; |
|
} |
|
|
|
|
|
return $result; |
|
} |
|
|
##------------------------------------------------------- write_gnuplot_file |
##------------------------------------------------------- write_gnuplot_file |
sub write_gnuplot_file { |
sub write_gnuplot_file { |
Line 1515 sub write_gnuplot_file {
|
Line 1818 sub write_gnuplot_file {
|
$curve->{'color'} : |
$curve->{'color'} : |
$Apache::lonplot::plot{'fgcolor'} ); |
$Apache::lonplot::plot{'fgcolor'} ); |
} |
} |
|
|
# set term |
# set term |
if ($target eq 'web') { |
if ($target eq 'web') { |
$gnuplot_input .= 'set terminal png enhanced nocrop '; |
$gnuplot_input .= 'set terminal png enhanced nocrop '; |
Line 1523 sub write_gnuplot_file {
|
Line 1827 sub write_gnuplot_file {
|
'/'.$font_properties->{'file'}.'.ttf" '; |
'/'.$font_properties->{'file'}.'.ttf" '; |
$gnuplot_input .= $fontsize; |
$gnuplot_input .= $fontsize; |
$gnuplot_input .= ' size '.$Apache::lonplot::plot{'width'}.','.$Apache::lonplot::plot{'height'}.' '; |
$gnuplot_input .= ' size '.$Apache::lonplot::plot{'width'}.','.$Apache::lonplot::plot{'height'}.' '; |
$gnuplot_input .= "@Colors\n"; |
if ($version > 4.6) { |
|
if ($Apache::lonplot::plot{'bgcolor'}) { |
|
$gnuplot_input .= "background '$Apache::lonplot::plot{'bgcolor'}'\n"; |
|
} |
|
} else { |
|
$gnuplot_input .= "@Colors\n"; |
|
} |
# set output |
# set output |
$gnuplot_input .= "set output\n"; |
$gnuplot_input .= "set output\n"; |
} elsif ($target eq 'tex') { |
} elsif ($target eq 'tex') { |
$gnuplot_input .= "set term postscript eps enhanced $Apache::lonplot::plot{'plotcolor'} solid "; |
$gnuplot_input .= "set term postscript eps enhanced $Apache::lonplot::plot{'plotcolor'} dash "; |
if (!$font_properties->{'tex_no_file'}) { |
if (!$font_properties->{'tex_no_file'}) { |
$gnuplot_input .= |
$gnuplot_input .= |
'fontfile "'.$Apache::lonnet::perlvar{'lonFontsDir'}. |
'fontfile "'.$Apache::lonnet::perlvar{'lonFontsDir'}. |
Line 1535 sub write_gnuplot_file {
|
Line 1845 sub write_gnuplot_file {
|
} |
} |
$gnuplot_input .= ' "'.$font_properties->{'printname'}.'" '; |
$gnuplot_input .= ' "'.$font_properties->{'printname'}.'" '; |
$gnuplot_input .= $fontsize; |
$gnuplot_input .= $fontsize; |
$gnuplot_input .= "\nset output \"/home/httpd/perl/tmp/". |
$gnuplot_input .= "\nset output \"".$tmpdir. |
&unescape($filename).".eps\"\n"; |
&unescape($filename).".eps\"\n"; |
|
$gnuplot_input .= "set encoding iso_8859_1\n"; # Get access to extended font. |
|
|
} |
} |
|
$gnuplot_input .= "set encoding utf8\n"; |
# cartesian or polar plot? |
# cartesian or polar plot? |
if (lc($Apache::lonplot::plot{'plottype'}) eq 'polar') { |
if (lc($Apache::lonplot::plot{'plottype'}) eq 'polar') { |
$gnuplot_input .= 'set polar'.$/; |
$gnuplot_input .= 'set polar'.$/; |
Line 1596 sub write_gnuplot_file {
|
Line 1909 sub write_gnuplot_file {
|
if ($Apache::lonplot::plot{'gridlayer'} eq 'on'); |
if ($Apache::lonplot::plot{'gridlayer'} eq 'on'); |
|
|
# grid |
# grid |
$gnuplot_input .= 'set grid'.$/ if ($Apache::lonplot::plot{'grid'} eq 'on'); |
if (($version > 4.6) && ($Apache::lonplot::plot{'fgcolor'} ne '')) { |
|
$gnuplot_input .= 'set grid linecolor "'.$Apache::lonplot::plot{'fgcolor'}.'"'.$/ |
|
if ($Apache::lonplot::plot{'grid'} eq 'on'); |
|
} else { |
|
$gnuplot_input .= 'set grid'.$/ if ($Apache::lonplot::plot{'grid'} eq 'on'); |
|
} |
# border |
# border |
$gnuplot_input .= ($Apache::lonplot::plot{'border'} eq 'on'? |
if ($Apache::lonplot::plot{'border'} eq 'on') { |
'set border'.$/ : |
if (($version > 4.6) && (($axis{'color'} ne '') || ($Apache::lonplot::plot{'fgcolor'} ne ''))) { |
'set noborder'.$/ ); |
$gnuplot_input .= 'set border linecolor "'. |
|
(($axis{'color'} ne '')?$axis{'color'}: |
|
$Apache::lonplot::plot{'fgcolor'}). |
|
'" '.$/; |
|
} else { |
|
$gnuplot_input .= 'set border '.$/; |
|
} |
|
} else { |
|
$gnuplot_input .= 'set noborder '.$/; |
|
} |
# sampling rate for non-data curves |
# sampling rate for non-data curves |
$gnuplot_input .= "set samples $Apache::lonplot::plot{'samples'}\n"; |
$gnuplot_input .= "set samples $Apache::lonplot::plot{'samples'}\n"; |
# title, xlabel, ylabel |
# title, xlabel, ylabel |
# titles |
# titles |
my $extra_space_x = ($xtics{'location'} eq 'axis') ? ' 0, -0.5 ' : ''; |
my $extra_space_x = ($xtics{'location'} eq 'axis') ? ' offset 0, -0.5 ' : ''; |
my $extra_space_y = ($ytics{'location'} eq 'axis') ? ' -0.5, 0 ' : ''; |
my $extra_space_y = ($ytics{'location'} eq 'axis') ? ' offset -0.5, 0 ' : ''; |
|
|
if ($target eq 'tex') { |
if ($target eq 'tex') { |
$gnuplot_input .= "set title \"$title\" font \"".$font_properties->{'printname'}.",".$fontsize."pt\"\n" if (defined($title)) ; |
$gnuplot_input .= "set title \"$title\" font \"".$font_properties->{'printname'}.",".$fontsize."pt\"\n" if (defined($title)) ; |
Line 1618 sub write_gnuplot_file {
|
Line 1945 sub write_gnuplot_file {
|
$gnuplot_input .= "set ylabel \"$ylabel\" $extra_space_y \n" if (defined($ylabel)); |
$gnuplot_input .= "set ylabel \"$ylabel\" $extra_space_y \n" if (defined($ylabel)); |
} |
} |
# tics |
# tics |
if (%xtics) { |
$gnuplot_input .= &generate_tics('xtics', \%xtics, $target); |
$gnuplot_input .= "set xtics $xtics{'location'} "; |
|
$gnuplot_input .= ( $xtics{'mirror'} eq 'on'?"mirror ":"nomirror "); |
$gnuplot_input .= &generate_tics('ytics', \%ytics, $target); |
$gnuplot_input .= "$xtics{'start'}, "; |
|
$gnuplot_input .= "$xtics{'increment'}, "; |
|
$gnuplot_input .= "$xtics{'end'}\n"; |
|
if ($xtics{'minorfreq'} != 0) { |
|
$gnuplot_input .= "set mxtics ".$xtics{'minorfreq'}."\n"; |
|
} |
|
} |
|
if (%ytics) { |
|
$gnuplot_input .= "set ytics $ytics{'location'} "; |
|
$gnuplot_input .= ( $ytics{'mirror'} eq 'on'?"mirror ":"nomirror "); |
|
$gnuplot_input .= "$ytics{'start'}, "; |
|
$gnuplot_input .= "$ytics{'increment'}, "; |
|
$gnuplot_input .= "$ytics{'end'}\n"; |
|
if ($ytics{'minorfreq'} != 0) { |
|
$gnuplot_input .= "set mytics ".$ytics{'minorfreq'}."\n"; |
|
} |
|
} |
|
# axis |
# axis |
if (%axis) { |
if (%axis) { |
if ($axis{'xformat'} ne 'on') { |
if ($axis{'xformat'} ne 'on') { |
Line 1658 sub write_gnuplot_file {
|
Line 1969 sub write_gnuplot_file {
|
} |
} |
$gnuplot_input .= "set xrange \[$axis{'xmin'}:$axis{'xmax'}\]\n"; |
$gnuplot_input .= "set xrange \[$axis{'xmin'}:$axis{'xmax'}\]\n"; |
$gnuplot_input .= "set yrange \[$axis{'ymin'}:$axis{'ymax'}\]\n"; |
$gnuplot_input .= "set yrange \[$axis{'ymin'}:$axis{'ymax'}\]\n"; |
|
if ($axis{'xzero'} ne 'off') { |
|
$gnuplot_input .= "set xzeroaxis "; |
|
if ($axis{'xzero'} eq 'line' || $axis{'xzero'} eq 'thick-line') { |
|
$gnuplot_input .= "lt -1 "; |
|
if ($axis{'xzero'} eq 'thick-line') { |
|
$gnuplot_input .= "lw 3 "; |
|
} |
|
} |
|
$gnuplot_input .= "\n"; |
|
} |
|
if ($axis{'yzero'} ne 'off') { |
|
$gnuplot_input .= "set yzeroaxis "; |
|
if ($axis{'yzero'} eq 'line' || $axis{'yzero'} eq 'thick-line') { |
|
$gnuplot_input .= "lt -1 "; |
|
if ($axis{'yzero'} eq 'thick-line') { |
|
$gnuplot_input .= "lw 3 "; |
|
} |
|
} |
|
$gnuplot_input .= "\n"; |
|
} |
} |
} |
# Key |
# Key |
if (%key) { |
if (%key) { |
Line 1680 sub write_gnuplot_file {
|
Line 2011 sub write_gnuplot_file {
|
$gnuplot_input .= ' '.$label->{'justify'}; |
$gnuplot_input .= ' '.$label->{'justify'}; |
|
|
if ($target eq 'tex') { |
if ($target eq 'tex') { |
$gnuplot_input .=' font "'.$font_properties->{'printname'}.','.$fontsize.'pt"' ; |
$gnuplot_input .=' font "'.$font_properties->{'printname'}.','.$fontsize.'pt"'; |
|
} |
|
if (($label->{'zlayer'} eq 'front') || ($label->{'zlayer'} eq 'back')) { |
|
$gnuplot_input .= ' '.$label->{'zlayer'}; |
} |
} |
$gnuplot_input .= $/; |
$gnuplot_input .= $/; |
} |
} |
Line 1689 sub write_gnuplot_file {
|
Line 2023 sub write_gnuplot_file {
|
$gnuplot_input .="\n"; |
$gnuplot_input .="\n"; |
} |
} |
# curves |
# curves |
$gnuplot_input .= 'plot '; |
# |
|
# Each curve will have its very own linestyle. |
|
# (This should work just fine in web rendition I think). |
|
# The line_xxx variables will hold the elements of the line style. |
|
# type (solid/dashed), color, width |
|
# |
|
my $linestyle_index = 50; |
|
my $line_width = ''; |
|
my $plots = ''; |
|
|
|
# If arrows are needed there will be an arrow style for each as well: |
|
# |
|
|
|
my $arrow_style_index = 50; |
|
|
for (my $i = 0;$i<=$#curves;$i++) { |
for (my $i = 0;$i<=$#curves;$i++) { |
$curve = $curves[$i]; |
$curve = $curves[$i]; |
$gnuplot_input.= ', ' if ($i > 0); |
my $plot_command = ''; |
|
my $plot_type = ''; |
|
if ($i > 0) { |
|
$plot_type = ', '; |
|
} |
if ($target eq 'tex') { |
if ($target eq 'tex') { |
$curve->{'linewidth'} *= 2; |
$curve->{'linewidth'} *= 2; |
} |
} |
|
$line_width = $curve->{'linewidth'}; |
if (exists($curve->{'function'})) { |
if (exists($curve->{'function'})) { |
$gnuplot_input.= |
$plot_type .= |
$curve->{'function'}.' title "'. |
$curve->{'function'}.' title "'. |
$curve->{'name'}.'" with '. |
$curve->{'name'}.'" with '. |
$curve->{'linestyle'}; |
$curve->{'linestyle'}; |
|
|
if (($curve->{'linestyle'} eq 'points') || |
|
($curve->{'linestyle'} eq 'linespoints') || |
|
($curve->{'linestyle'} eq 'errorbars') || |
|
($curve->{'linestyle'} eq 'xerrorbars') || |
|
($curve->{'linestyle'} eq 'yerrorbars') || |
|
($curve->{'linestyle'} eq 'xyerrorbars')) { |
|
$gnuplot_input.=' pointtype '.$curve->{'pointtype'}; |
|
$gnuplot_input.=' pointsize '.$curve->{'pointsize'}; |
|
} elsif ($curve->{'linestyle'} eq 'filledcurves') { |
|
$gnuplot_input.= ' '.$curve->{'limit'}; |
|
} elsif ($curve->{'linetype'} ne '' && |
|
$curve->{'linestyle'} eq 'lines') { |
|
$gnuplot_input.= ' linetype '; |
|
$gnuplot_input.= $linetypes{$curve->{'linetype'}}; |
|
$gnuplot_input.= ' linecolor rgb "'; |
|
# convert color from xaaaaaa to #aaaaaa |
|
$curve->{'color'} =~ s/^x/#/; |
|
$gnuplot_input.= $curve->{'color'}.'"'; |
|
} |
|
$gnuplot_input.= ' linewidth '.$curve->{'linewidth'}; |
|
|
|
} elsif (exists($curve->{'data'})) { |
} elsif (exists($curve->{'data'})) { |
# Store data values in $datatext |
# Store data values in $datatext |
my $datatext = ''; |
my $datatext = ''; |
Line 1743 sub write_gnuplot_file {
|
Line 2074 sub write_gnuplot_file {
|
print $fh $datatext; |
print $fh $datatext; |
close($fh); |
close($fh); |
# generate gnuplot text |
# generate gnuplot text |
$gnuplot_input.= '"'.$datafilename.'" title "'. |
$plot_type .= '"'.$datafilename.'" title "'. |
$curve->{'name'}.'" with '. |
$curve->{'name'}.'" with '. |
$curve->{'linestyle'}; |
$curve->{'linestyle'}; |
if (($curve->{'linestyle'} eq 'points') || |
|
($curve->{'linestyle'} eq 'linespoints') || |
|
($curve->{'linestyle'} eq 'errorbars') || |
|
($curve->{'linestyle'} eq 'xerrorbars') || |
|
($curve->{'linestyle'} eq 'yerrorbars') || |
|
($curve->{'linestyle'} eq 'xyerrorbars')) { |
|
$gnuplot_input.=' pointtype '.$curve->{'pointtype'}; |
|
$gnuplot_input.=' pointsize '.$curve->{'pointsize'}; |
|
} elsif ($curve->{'linestyle'} eq 'filledcurves') { |
|
$gnuplot_input.= ' '.$curve->{'limit'}; |
|
} elsif ($curve->{'linetype'} ne '' && |
|
$curve->{'linestyle'} eq 'lines') { |
|
$gnuplot_input.= ' linetype '; |
|
$gnuplot_input.= $linetypes{$curve->{'linetype'}}; |
|
$gnuplot_input.= ' linecolor rgb "'; |
|
# convert color from xaaaaaa to #aaaaaa |
|
$curve->{'color'} =~ s/^x/#/; |
|
$gnuplot_input.= $curve->{'color'}.'"'; |
|
} |
|
$gnuplot_input.= ' linewidth '.$curve->{'linewidth'}; |
|
} |
} |
|
my $pointtype = ''; |
|
my $pointsize = ''; |
|
|
|
# Figure out the linestyle: |
|
|
|
my $lt = $curve->{'linetype'} ne '' ? $curve->{'linetype'} |
|
: 'solid'; # Line type defaults to solid. |
|
# The mapping of lt -> the actual gnuplot line type depends on the target: |
|
|
|
if ($target eq 'tex') { |
|
$lt = $ps_linetypes{$lt}; |
|
} else { |
|
$lt = $linetypes{$lt} |
|
} |
|
|
|
my $color = $curve->{'color'}; |
|
$color =~ s/^x/#/; # Convert xhex color -> #hex color. |
|
|
|
|
|
if (($curve->{'linestyle'} eq 'points') || |
|
($curve->{'linestyle'} eq 'linespoints') || |
|
($curve->{'linestyle'} eq 'errorbars') || |
|
($curve->{'linestyle'} eq 'xerrorbars') || |
|
($curve->{'linestyle'} eq 'yerrorbars') || |
|
($curve->{'linestyle'} eq 'xyerrorbars')) { |
|
|
|
$pointtype =' pointtype '.$curve->{'pointtype'}; |
|
$pointsize =' pointsize '.$curve->{'pointsize'}; |
|
} elsif ($curve->{'linestyle'} eq 'filledcurves') { |
|
$plot_command.= ' '.$curve->{'limit'}; |
|
} elsif ($curve->{'linestyle'} eq 'vector') { |
|
|
|
# Create the arrow head style add it to |
|
# $gnuplot_input..and ensure it gets |
|
# Selected in the plot command. |
|
|
|
$gnuplot_input .= "set style arrow $arrow_style_index "; |
|
$gnuplot_input .= ' ' . $curve->{'arrowhead'}; |
|
$gnuplot_input .= ' size ' . $curve->{'arrowlength'}; |
|
$gnuplot_input .= ','.$curve->{'arrowangle'}; |
|
$gnuplot_input .= ',' . $curve->{'arrowbackangle'}; |
|
$gnuplot_input .= ' ' . $curve->{'arrowstyle'} . " ls $linestyle_index\n"; |
|
|
|
|
|
$plot_command .= " arrowstyle $arrow_style_index "; |
|
$arrow_style_index++; |
|
} |
|
|
|
my $style_command = "set style line $linestyle_index $pointtype $pointsize linetype $lt linewidth $line_width lc rgb '$color'\n"; |
|
$gnuplot_input .= $style_command; |
|
|
|
# The condition below is because gnuplot lumps the linestyle in with the |
|
# arrowstyle _sigh_. |
|
|
|
if ($curve->{'linestyle'} ne 'vector') { |
|
$plot_command.= " ls $linestyle_index"; |
|
} |
|
|
|
$plots .= $plot_type . ' ' . $plot_command; |
|
$linestyle_index++; # Each curve get a unique linestyle. |
} |
} |
|
$gnuplot_input .= 'plot '.$plots; |
# Write the output to a file. |
# Write the output to a file. |
open (my $fh,">$tmpdir$filename.data"); |
|
binmode($fh, ":utf8"); |
# &Apache::lonnet::logthis($gnuplot_input); # uncomment to log the gnuplot input. |
|
open (my $fh, "> $tmpdir$filename.data"); |
|
binmode($fh, ':utf8'); |
print $fh $gnuplot_input; |
print $fh $gnuplot_input; |
close($fh); |
close($fh); |
# That's all folks. |
# That's all folks. |
Line 1817 sub edit_attributes {
|
Line 2191 sub edit_attributes {
|
if ($defaults->{$attr}->{'edit_type'} eq 'entry') { |
if ($defaults->{$attr}->{'edit_type'} eq 'entry') { |
$result .= &Apache::edit::text_arg |
$result .= &Apache::edit::text_arg |
($description,$attr,$token, |
($description,$attr,$token, |
$defaults->{$attr}->{'size'}); |
$defaults->{$attr}->{'size'}, |
|
$defaults->{$attr}->{'class'}); |
} elsif ($defaults->{$attr}->{'edit_type'} eq 'choice') { |
} elsif ($defaults->{$attr}->{'edit_type'} eq 'choice') { |
$result .= &Apache::edit::select_or_text_arg |
$result .= &Apache::edit::select_or_text_arg |
($description,$attr,$defaults->{$attr}->{'choices'},$token); |
($description,$attr,$defaults->{$attr}->{'choices'},$token); |
Line 1946 sub insert_data {
|
Line 2321 sub insert_data {
|
__END__ |
__END__ |
|
|
|
|
|
=head1 NAME |
|
|
|
Apache::lonplot.pm |
|
|
|
=head1 SYNOPSIS |
|
|
|
XML-based plotter of graphs |
|
|
|
This is part of the LearningOnline Network with CAPA project |
|
described at http://www.lon-capa.org. |
|
|
|
|
|
=head1 SUBROUTINES (parsing and edit rendering) |
|
|
|
=over |
|
|
|
=item start_gnuplot() |
|
|
|
=item end_gnuplot() |
|
|
|
=item start_xtics() |
|
|
|
=item end_xtics() |
|
|
|
=item start_ytics() |
|
|
|
=item end_ytics() |
|
|
|
=item get_font() |
|
|
|
=item start_key() |
|
|
|
=item end_key() |
|
|
|
=item parse_label() |
|
|
|
=item replace_entities() |
|
|
|
=item start_title() |
|
|
|
=item end_title() |
|
|
|
=item start_xlabel() |
|
|
|
=item end_xlabel() |
|
|
|
=item start_ylabel() |
|
|
|
=item end_label() |
|
|
|
=item start_curve() |
|
|
|
=item end_curve() |
|
|
|
=item start_function() |
|
|
|
=item end_function() |
|
|
|
=item start_data() |
|
|
|
=item end_data() |
|
|
|
=item start_axis() |
|
|
|
=item end_axis |
|
|
|
=back |
|
|
|
=head1 SUBROUTINES (Utility) |
|
|
|
=over |
|
|
|
=item set_defaults() |
|
|
|
=item get_attributes() |
|
|
|
=item write_gnuplot_file() |
|
|
|
=item check_inputs() |
|
|
|
=item edit_attributes() |
|
|
|
=back |
|
|
|
=head1 SUBROUTINES (Insertion functions for editing plots) |
|
|
|
=over |
|
|
|
=item insert_gnuplot() |
|
|
|
=item insert_tics() |
|
|
|
=item insert_xtics() |
|
|
|
=item insert_key() |
|
|
|
=item insert_axis() |
|
|
|
=item insert_title() |
|
|
|
=item insert_xlabel() |
|
|
|
=item insert_ylabel() |
|
|
|
=item insert_label() |
|
|
|
=item insert_curve() |
|
|
|
=item insert_function() |
|
|
|
=item insert_data() |
|
|
|
=back |
|
|
|
=cut |