--- loncom/homework/randomlabel.pm 2003/09/23 21:20:42 1.49 +++ loncom/homework/randomlabel.pm 2003/10/30 20:52:54 1.52 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # random labelling tool # -# $Id: randomlabel.pm,v 1.49 2003/09/23 21:20:42 albertel Exp $ +# $Id: randomlabel.pm,v 1.52 2003/10/30 20:52:54 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -92,7 +92,7 @@ sub start_randomlabel { } my $w= &check_int(&Apache::lonxml::get_param('width',$parstack,$safeeval)); my $h= &check_int(&Apache::lonxml::get_param('height',$parstack,$safeeval)); - my $texwidth= &Apache::lonxml::get_param('texwidth',$parstack,$safeeval,undef,1); + my $texwidth=&adjust_textwidth(&Apache::lonxml::get_param('texwidth',$parstack,$safeeval,undef,1)); if (!$texwidth) { $texwidth=90; } $Apache::randomlabel::tlabel_cnt=0; $Apache::randomlabel::ilabel_cnt=0; @@ -120,20 +120,14 @@ sub start_randomlabel { $temp_file = Apache::File->new('>>'.$filename); $newbgimg =~ s/(.*)\/res\//\/home\/httpd\/html\/res\//; print $temp_file "$newbgimg\n"; - $bgimg =~ m/\/([^\/]+)$/; - $bgimg = '/home/httpd/prtspool/'.$1; - } + $bgimg=~s/\/home\/httpd\/html\/res/\/home\/httpd\/prtspool/; } } } $bgimg=~s/\/$//; my $dirtywidth=$texwidth+5; - if ($texwidth==90) { - $result.='\vspace*{2mm}\noindent \parbox{'.$dirtywidth.' mm}{ \noindent \epsfxsize='.$texwidth.' mm \epsffile{'. - $bgimg.'}\setlength{\unitlength}{1mm} \begin{picture}('.$texwidth.','.$texwidth*$h/$w.')(0,-'.$texwidth*$h/$w.')'; - } else { - $result.='\vspace*{2mm}\noindent \parbox{'.$dirtywidth.' mm}{ \noindent \epsfxsize='.$texwidth.' mm \epsffile{'. - $bgimg.'}\setlength{\unitlength}{1mm} \begin{picture}('.$texwidth.','.$texwidth*$h/$w.')(0,-'.$texwidth*$h/$w.')'; - } + $result.='\vspace*{2mm}\noindent \parbox{'.$dirtywidth.' mm}{ \noindent \epsfxsize='. + $texwidth.' mm \epsffile{'.$bgimg.'}\setlength{\unitlength}{1mm} \begin{picture}('. + $texwidth.','.$texwidth*$h/$w.')(0,-'.$texwidth*$h/$w.')'; } elsif ($target eq 'edit') { $result.=&Apache::edit::tag_start($target,$token); $Apache::edit::bgimgsrc= @@ -179,7 +173,7 @@ sub end_randomlabel { $result='\end{picture}\\\\'; my $height=&Apache::lonxml::get_param('height',$parstack,$safeeval); my $width=&Apache::lonxml::get_param('width',$parstack,$safeeval); - my $texwidth=&Apache::lonxml::get_param('texwidth',$parstack,$safeeval,undef,1); + my $texwidth=&adjust_textwidth(&Apache::lonxml::get_param('texwidth',$parstack,$safeeval,undef,1)); if (!$texwidth) { $texwidth=90; } my $howtoskipback = $texwidth*$height/$width; $result.= ' \vskip -'.$howtoskipback.' mm } \\\\ '; @@ -189,6 +183,14 @@ sub end_randomlabel { return $result; } +sub adjust_textwidth { + my $texwidth=shift; + my $pagewidth=$ENV{'form.textwidth'}; + $pagewidth=~s/\s*mm\s*$//; + if ($texwidth>$pagewidth) {$texwidth=$pagewidth;} + return $texwidth; +} + sub start_labelgroup { my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; my $result=''; @@ -287,7 +289,7 @@ sub end_labelgroup { my $WY1=0; # Web y-coord. of (ULC) my $wwidth=&Apache::lonxml::get_param('width',$parstack,$safeeval,-2); my $wheight=&Apache::lonxml::get_param('height',$parstack,$safeeval,-2); - my $texwidth=&Apache::lonxml::get_param('texwidth',$parstack,$safeeval,-2,1); + my $texwidth=&adjust_textwidth(&Apache::lonxml::get_param('texwidth',$parstack,$safeeval,-2,1)); if (!$texwidth) { $texwidth=90; } my $TX1=0; my $TY1=$texwidth*($wheight/$wwidth); @@ -402,7 +404,6 @@ sub start_label { $result.=&Apache::edit::editline('',$text,'',50). &Apache::edit::end_table(); } elsif ($target eq 'modified') { - my $text=$$parser[-1]->get_text("/label"); $result = '