/[pliva-si]/m/menu.pl
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /m/menu.pl

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1.5 by dpavlin, Fri Jun 29 11:12:59 2001 UTC revision 1.9 by dpavlin, Wed Nov 7 15:02:56 2001 UTC
# Line 7  use Image::Magick; Line 7  use Image::Magick;
7  use constant TYPE_NONE => scalar 2;  use constant TYPE_NONE => scalar 2;
8  use constant TYPE_BULLET => scalar 3;  use constant TYPE_BULLET => scalar 3;
9  use constant TYPE_LINE => scalar 1;  use constant TYPE_LINE => scalar 1;
10    use constant TYPE_BLUEDOT => scalar 4;
11    
12  # size of menu image  # size of menu image
13  my $w=125;  my $w=125;
14  my $h_base=13;  my $h_base=13;
15  my $h;  my $h;
16    
17    my $dir="/data/pliva-si/m";
18    #my $font="arialbd.ttf";
19    my $font="trebucbd.ttf";
20    
21    my %iso2utf_tab = (
22    '¹' => 0x0161, 'ð' => 0x0111, 'è' => 0x010d, 'æ' => 0x0107, '¾' => 0x017e,
23    '©' => 0x0160, 'Ð' => 0x0110, 'È' => 0x010c, 'Æ' => 0x0106, '®' => 0x017d
24    );
25    
26    sub iso2utf {
27            local($_)=@_;
28    
29            sub utf8 {
30                    local($_)=@_;
31                    return $_ < 0x80 ? chr($_) :
32                     $_ < 0x800 ? chr($_>>6&0x3F|0xC0) . chr($_&0x3F|0x80) :
33                      chr($_>>12&0x0F|0xE0).chr($_>>6&0x3F|0x80).chr($_&0x3F|0x80);
34            }
35            s/([¹ðè澩ÐÈÆ®])/utf8($iso2utf_tab{$1})/ge;
36            return $_;
37    }
38    
39  sub dump_gif {  sub dump_gif {
40          my ($text, $type, $file) = @_;          my ($text, $type, $file) = @_;
41          $type ||= TYPE_NONE;          $type ||= TYPE_NONE;
42          $file ||= $text;          $file ||= "$text-$type";
43          $file =~ s/[^a-zA-Z0-9\-]/_/g;          $file =~ s/[^a-zA-Z0-9\-]/_/g;
44          $file = lc($file);          $file = lc($file);
45          print "$text" unless ($file eq "-");          print "$text" unless ($file eq "-");
# Line 27  sub dump_gif { Line 50  sub dump_gif {
50          my $image = Image::Magick->new;          my $image = Image::Magick->new;
51          $image->Set('size' => "${w}x${h}");          $image->Set('size' => "${w}x${h}");
52          $image->Read('xc:#283880');          $image->Read('xc:#283880');
53            $text=~tr/šðžèæŠÐŽÈÆ/¹ð¾èæ©Ð®ÈÆ/;       # 1250 -> iso8859-2
54            $text=iso2utf($text);
55          if ($type == TYPE_BULLET) {          if ($type == TYPE_BULLET) {
56                  $image->Annotate('text' => $text, 'geometry' => '+17+10',                  $image->Annotate('text' => $text, 'geometry' => '+17+10',
57                          'font' => "\@arialbd.ttf", 'pointsize' => 11,                          'font' => "\@$dir/$font", 'pointsize' => 11,
58                          'fill' => '#ffffff', 'align' => 'left');                          'fill' => '#ffffff', 'align' => 'left');
59  #               $image->Annotate('text' => $text, 'geometry' => '+17+1',  #               $image->Annotate('text' => $text, 'geometry' => '+17+1',
60  #                       'font' => "\@arialbd.ttf", 'pointsize' => 11,  #                       'font' => "\@$dir/$font", 'pointsize' => 11,
61  #                       'pen' => '#FFFFFF', 'align' => 'left');  #                       'pen' => '#FFFFFF', 'align' => 'left');
62  #               $image->Blur('radius' => 0.1);  #               $image->Blur('radius' => 0.1);
63                  $image->Draw('primitive' => 'rectangle', 'stroke' => '#00D000',                  $image->Draw('primitive' => 'rectangle', 'stroke' => '#00D000',
64                          'fill' => '#00D000', 'antialias' => 1, 'points' =>                          'fill' => '#00D000', 'antialias' => 1, 'points' =>
65                          '7,4 10,7');                          '7,4 10,7');
66            } elsif ($type == TYPE_BLUEDOT) {
67                    $image->Annotate('text' => $text, 'geometry' => '+17+10',
68                            'font' => "\@$dir/$font", 'pointsize' => 11,
69                            'fill' => '#ffffff', 'align' => 'left');
70                    $image->Draw('primitive' => 'rectangle', 'stroke' => '#00b2dc',
71                            'fill' => '#00b2dc', 'antialias' => 1, 'points' =>
72                            '7,4 10,7');
73          } else {          } else {
74                  if ($type == TYPE_LINE) {                  if ($type == TYPE_LINE) {
75                          $image->Draw('primitive' => 'line',                          $image->Draw('primitive' => 'line',
# Line 61  sub dump_gif { Line 93  sub dump_gif {
93                          }                          }
94                  }                  }
95                  $image->Annotate('text' => $text, 'geometry' => '+3+10',                  $image->Annotate('text' => $text, 'geometry' => '+3+10',
96                          'font' => "\@arialbd.ttf", 'pointsize' => 11,                          'font' => "\@$dir/$font", 'pointsize' => 11,
97                          'fill' => '#FFFFFF', 'align' => 'left');                          'fill' => '#FFFFFF', 'align' => 'left');
98  #               $image->Blur('radius' => 1);  #               $image->Blur('radius' => 1);
99          }          }
100          print " -> " unless ($file eq "-");          print " -> " unless ($file eq "-");
101          $file .= ".gif" unless ($file eq "-");          $file .= ".gif" unless ($file eq "-");
102          $image->Write('filename' => "gif:$file", 'colors' => 256,          $image->Write('filename' => "gif:$dir/$file", 'colors' => 256,
103                  'interlace' => "none", 'compress' => 'lzw');                  'interlace' => "none", 'compress' => 'lzw');
104          print "$file\n" unless ($file eq "-");          print "$file\n" unless ($file eq "-");
105          return "$file";          return "$file";
# Line 77  sub dump_gif { Line 109  sub dump_gif {
109  #dump_gif("NOVOSTI", TYPE_LINE, "-");  #dump_gif("NOVOSTI", TYPE_LINE, "-");
110  #exit $?;  #exit $?;
111    
112  my $dbh = DBI->connect("DBI:Pg:dbname=plivasi", "", "") ||  #
113    my $dbh = DBI->connect("DBI:Pg:dbname=plivasi", "dpavlin", "") ||
114          die $DBI::errstr;          die $DBI::errstr;
115  my $sth = $dbh->prepare("SELECT section,item,url,level,num FROM menu") ||  my $sth = $dbh->prepare("SELECT section,item,url,level,num FROM menu") ||
116          die $dbh->errstr();          die $dbh->errstr();

Legend:
Removed from v.1.5  
changed lines
  Added in v.1.9

  ViewVC Help
Powered by ViewVC 1.1.26