NAME

Tk::Chart::FAQ - Frequently Asked Questions about Tk::Chart.

SYNOPSIS

This is the Frequently Asked Questions list for Tk::Chart.

DESCRIPTION

How to scrolled Tk::Chart Widget ?

Tk::Chart is an extension of Canvas widget. That is an idea to scrolled your widget if you use Tk::Chart::Lines :

my $LineGraph = $mw->Scrolled('Lines')->pack;

You can also use Scrollbar method or use scrolled frame as Pane widget like this example :

#!/usr/bin/perl
use strict;
use warnings;
use Tk;
use Tk::Chart::Mixed;
use Tk::Pane;

my $mw = new MainWindow(
  -title      => 'Scrolled Graph',
  -background => 'white',
);

my $pane = $mw->Scrolled(
  'Pane',
  -scrollbars => 'osoe',
  -sticky     => 'nswe',
  -width      => 300,
  -height     => 300,
);
$pane->Frame;
$pane->pack(qw / -fill both -expand 1 /);

my @types        = qw/ areas bars lines points bars linespoints/;
my $Chart = $pane->Mixed(
  -title      => 'My graph title',
  -xlabel     => 'X Label',
  -ylabel     => 'Y Label',
  -background => '#D0D0FF',
  -linewidth  => 2,
  -width      => 600,
  -height     => 600,
  -spacingbar => 0,
  -typemixed  => \@types,
  -markers    => [ 3, 5, 6 ],
)->pack(qw / -fill both -expand 1 /);

my @data = (
  [ '1st', '2nd', '3rd', '4th', '5th', '6th', '7th', '8th', '9th' ],
  [ 90,    29,    25,    6,     -20,   1,     1,     3,     4 ],
  [ 15,    10,    5,     2,     3,     5,     7,     9,     12 ],
  [ 1,     2,     12,    6,     3,     5,     1,     23,    5 ],
  [ 15,    12,    24,    33,    19,    8,     6,     15,    21 ],
  [ 15,    2,     52,    6,     3,     17.5,  1,     43,    10 ],
  [ 30,    2,     5,     6,     3,     1.5,   1,     3,     4 ],
  [ 24,    12,    35,    20,    13,    31.5,  41,    6,     25 ],

);

# Add a legend to the graph
my @Legends = @types;
$Chart->set_legend(
  -title       => "Title legend",
  -data        => [ 'legend 1', 'legend 2', 'legend 3', 'legend 4', 'legend 5', 'legend 6', 'legend 7', ],
  -titlecolors => "blue",
);

# Add help identification
$Chart->set_balloon();

# Create the graph
$Chart->plot( \@data );

MainLoop();

NB: The graph have a minimum size (by default 400x400). Then if you want to reduce this size, configure -width and -height option at the creation of the graph.

How to save graph in postscript, jpeg, png, gif format file ?

You can use the postscript method canvas (see Tk::Canvas) to create postscript file of your image.

$Chart->postscript( -file => "MyFile.ps");

If you want to convert it in gif, jpeg format file for example, you can install Image::Magick module and Ghostscript (http://pages.cs.wisc.edu/~ghost/).

Example code for postscript file conversion:

use Image::Magick;
my $Magick = new Image::Magick;
$Magick->Read("MyFile.ps");
$Magick->Write("MyFile.png");

How to zoom the graph in canvas widget ?

To zoom your graph, use zoom, zoomx or zoomy methods. You can create a menu zoom on the canvas. You have an example code in "EXAMPLES" in Tk::Chart::Lines

Warning or fatal error messages

You must have at least 2 arrays

eg:
my @data = (
     [ '1st', '2nd', '3rd', '4th', '5th', '6th', '7th', '8th', '9th' ],
);
$PieChart->plot(\@data);
# => you will get warning message

You must have 2 arrays in data array

You will have this warning if you use Tk::Chart::Pie and if you use plot method with bad data.

eg:
my @data = (
     [ '1st', '2nd', '3rd', '4th', '5th', '6th', '7th', '8th', '9th' ],
     [     1,     2,    52,    6,      3,  17.5,     1,    43,    10 ],
     [    11,    20,     2,    5,      3,     1,    12,     3,     0 ], 
);
$PieChart->plot(\@data);

# => you will get warning message

my @data = (
     [ '1st', '2nd', '3rd', '4th', '5th', '6th', '7th', '8th', '9th' ],
     [     1,     2,    52,    6,      3,  17.5,     1,    43,    10 ], 
);
$PieChart->plot(\@data);
# OK

Make sure that every array has the same size in plot data method

eg:
my @data = (
  [ 'Europe', 'Asia', 'Africa', 'Oceania', 'Americas' ], # <= 5 data 
  [ 97,       33,     3,        6,         61, 1100 ],   # <= 6 data , wrong
);
$PieChart->plot(\@data);

Data not defined

$PieChart->plot(); # wrong

Can't set -data in set_legend method. May be you forgot to set the value

$Chart->set_legend(
  -data        => undef,     # wrong
);

$Chart->set_legend(); # wrong

$Chart->set_legend(
  -data        => \@Legends,     # OK
);

Legend and array size data are different

my @data = (
  [ '1st', '2nd', '3rd', '4th', '5th', '6th', '7th', '8th', '9th' ],
  [ 1,     2,     5,     6,     3,     1,     1,     3,     4 ],  # legend 1
  [ 4,     2,     5,     2,     3,     5,     7,     9,     12 ], # legend 2
  [ 1,     2,     12,    6,     3,     5,     1,     23,    5 ]   # legend 3
);

my @Legends = ( 'legend 1', 'legend 2', 'legend 3', 'legend 4' ); # Wrong, 
# too much legend

my @Legends = ( 'legend 1', 'legend 2' ); # Wrong, not enough  legend

my @Legends = ( 'legend 1', 'legend 2', 'legend 3' ); # OK

When I draw a chart with high values with short interval, the Y axe does not take the minimum value of data but always 0, how to change it ?

You have to use the version 1.14 or higher of Tk::Chart and use -interval or -yminvalue and -ymaxvalue options.

You can see examples in demo directory.

SEE ALSO

Tk::Chart

COPYRIGHT & LICENSE

Copyright 2010 Djibril Ousmanou, all rights reserved.

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.