Tutorials: Tutorial 1 Tutorial 2 Tutorial 3 Tutorial 4 Tutorial 5 Tutorial 6 Tutorial 7
Tutorials: Tutorial 1 Tutorial 2 Tutorial 3 Tutorial 4 Tutorial 5 Tutorial 6 Tutorial 7
Tutorials: Tutorial 1 Tutorial 2 Tutorial 3 Tutorial 4 Tutorial 5 Tutorial 6 Tutorial 7
Tutorials
The different examples rapidly show how to use FPDF. You will find all main features explained.
Minimal example
Let's start with the classic example:
<?php
require('fpdf.php');
$pdf=new FPDF();
$pdf->AddPage();
$pdf->SetFont('Arial','B',16);
$pdf->Cell(40,10,'Hello World!');
$pdf->Output();
?>
[Demo]
After including the library file, we create an FPDF object. The FPDF() constructor is used here with the
default values: pages are in A4 portrait and the unit of measure is millimeter. It could have been
specified explicitly with:
$pdf=new FPDF('P','mm','A4');
It is possible to use landscape (L), other page formats (such as Letter and Legal) and units of measure
(pt, cm, in).
There is no page for the moment, so we have to add one with AddPage(). The origin is at the upper-left
corner and the current position is by default placed at 1 cm from the borders; the margins can be
changed with SetMargins().
Before we can print text, it is mandatory to select a font with SetFont(), otherwise the document would
be invalid. We choose Arial bold 16:
$pdf->SetFont('Arial','B',16);
We could have specified italics with I, underlined with U or a regular font with an empty string (or any
combination). Note that the font size is given in points, not millimeters (or another user unit); it is the
only exception. The other standard fonts are Times, Courier, Symbol and ZapfDingbats.
We can now print a cell with Cell(). A cell is a rectangular area, possibly framed, which contains a line
of text. It is output at the current position. We specify its dimensions, its text (centered or aligned), if
borders should be drawn, and where the current position moves after it (to the right, below or to the
beginning of the next line). To add a frame, we would do this:
To add a new cell next to it with centered text and go to the next line, we would do:
$pdf->Cell(60,10,'Powered by FPDF.',0,1,'C');
Remark: the line break can also be done with Ln(). This method additionnaly allows to specify the
height of the break.
Finally, the document is closed and sent to the browser with Output(). We could have saved it to a file
by passing the desired file name.
Caution: in case when the PDF is sent to the browser, nothing else must be output by the script, neither
before nor after (no HTML, not even a space or a carriage return). If you send something before, you
will get the error message: "Some data has already been output, can't send PDF file". If you send
something after, the document might not display.
<?php
require('fpdf.php');
//Page footer
function Footer()
{
//Position at 1.5 cm from bottom
$this->SetY(-15);
//Arial italic 8
$this->SetFont('Arial','I',8);
//Page number
$this->Cell(0,10,'Page '.$this->PageNo().'/{nb}',0,0,'C');
}
}
[Demo]
This example makes use of the Header() and Footer() methods to process page headers and footers. They
are called automatically. They already exist in the FPDF class but do nothing, therefore we have to
extend the class and override them.
The logo is printed with the Image() method by specifying its upper-left corner and its width. The height
is calculated automatically to respect the image proportions.
To print the page number, a null value is passed as the cell width. It means that the cell should extend up
to the right margin of the page; it is handy to center text. The current page number is returned by the
PageNo() method; as for the total number of pages, it is obtained by means of the special value {nb}
which will be substituted on document closure (provided you first called AliasNbPages()).
Note the use of the SetY() method which allows to set position at an absolute location in the page,
starting from the top or the bottom.
Another interesting feature is used here: the automatic page breaking. As soon as a cell would cross a
limit in the page (at 2 centimeters from the bottom by default), a break is performed and the font
restored. Although the header and footer select their own font (Arial), the body continues with Times.
This mechanism of automatic restoration also applies to colors and line width. The limit which triggers
page breaks can be set with SetAutoPageBreak().
<?php
require('fpdf.php');
//Arial bold 15
$this->SetFont('Arial','B',15);
//Calculate width of title and position
$w=$this->GetStringWidth($title)+6;
$this->SetX((210-$w)/2);
//Colors of frame, background and text
$this->SetDrawColor(0,80,180);
$this->SetFillColor(230,230,0);
$this->SetTextColor(220,50,50);
//Thickness of frame (1 mm)
$this->SetLineWidth(1);
//Title
$this->Cell($w,9,$title,1,1,'C',true);
//Line break
$this->Ln(10);
}
function Footer()
{
//Position at 1.5 cm from bottom
$this->SetY(-15);
//Arial italic 8
$this->SetFont('Arial','I',8);
//Text color in gray
$this->SetTextColor(128);
//Page number
$this->Cell(0,10,'Page '.$this->PageNo(),0,0,'C');
}
function ChapterTitle($num,$label)
{
//Arial 12
$this->SetFont('Arial','',12);
//Background color
$this->SetFillColor(200,220,255);
//Title
$this->Cell(0,6,"Chapter $num : $label",0,1,'L',true);
//Line break
$this->Ln(4);
}
function ChapterBody($file)
{
//Read text file
$f=fopen($file,'r');
$txt=fread($f,filesize($file));
fclose($f);
//Times 12
$this->SetFont('Times','',12);
//Output justified text
$this->MultiCell(0,5,$txt);
//Line break
$this->Ln();
//Mention in italics
$this->SetFont('','I');
$this->Cell(0,5,'(end of excerpt)');
}
function PrintChapter($num,$title,$file)
{
$this->AddPage();
$this->ChapterTitle($num,$title);
$this->ChapterBody($file);
}
}
$pdf=new PDF();
$title='20000 Leagues Under the Seas';
$pdf->SetTitle($title);
$pdf->SetAuthor('Jules Verne');
$pdf->PrintChapter(1,'A RUNAWAY REEF','20k_c1.txt');
$pdf->PrintChapter(2,'THE PROS AND CONS','20k_c2.txt');
$pdf->Output();
?>
[Demo]
The GetStringWidth() method allows to determine the length of a string in the current font, which is
used here to calculate the position and the width of the frame surrounding the title. Then colors are set
(via SetDrawColor(), SetFillColor() and SetTextColor()) and the thickness of the line is set to 1 mm
(against 0.2 by default) with SetLineWidth(). Finally, we output the cell (the last parameter to true
indicates that the background must be filled).
The method used to print the paragraphs is MultiCell(). Each time a line reaches the right extremity of
the cell or a carriage return character is met, a line break is issued and a new cell automatically created
under the current one. Text is justified by default.
Two document properties are defined: the title (SetTitle()) and the author (SetAuthor()). Properties can
be viewed by two means. First is to open the document directly with Acrobat Reader, go to the File
menu and choose the Document Properties option. The second, also available from the plug-in, is to
right-click and select Document Properties.
Multi-columns
This example is a variant of the previous one showing how to lay the text across multiple columns.
<?php
require('fpdf.php');
function Header()
{
//Page header
global $title;
$this->SetFont('Arial','B',15);
$w=$this->GetStringWidth($title)+6;
$this->SetX((210-$w)/2);
$this->SetDrawColor(0,80,180);
$this->SetFillColor(230,230,0);
$this->SetTextColor(220,50,50);
$this->SetLineWidth(1);
$this->Cell($w,9,$title,1,1,'C',true);
$this->Ln(10);
//Save ordinate
$this->y0=$this->GetY();
}
function Footer()
{
//Page footer
$this->SetY(-15);
$this->SetFont('Arial','I',8);
$this->SetTextColor(128);
$this->Cell(0,10,'Page '.$this->PageNo(),0,0,'C');
}
function SetCol($col)
{
//Set position at a given column
$this->col=$col;
$x=10+$col*65;
$this->SetLeftMargin($x);
$this->SetX($x);
function AcceptPageBreak()
{
//Method accepting or not automatic page break
if($this->col<2)
{
//Go to next column
$this->SetCol($this->col+1);
//Set ordinate to top
$this->SetY($this->y0);
//Keep on page
return false;
}
else
{
//Go back to first column
$this->SetCol(0);
//Page break
return true;
}
}
function ChapterTitle($num,$label)
{
//Title
$this->SetFont('Arial','',12);
$this->SetFillColor(200,220,255);
$this->Cell(0,6,"Chapter $num : $label",0,1,'L',true);
$this->Ln(4);
//Save ordinate
$this->y0=$this->GetY();
}
function ChapterBody($file)
{
//Read text file
$f=fopen($file,'r');
$txt=fread($f,filesize($file));
fclose($f);
//Font
$this->SetFont('Times','',12);
//Output text in a 6 cm width column
$this->MultiCell(60,5,$txt);
$this->Ln();
//Mention
$this->SetFont('','I');
$this->Cell(0,5,'(end of excerpt)');
//Go back to first column
$this->SetCol(0);
}
function PrintChapter($num,$title,$file)
{
//Add chapter
$this->AddPage();
$this->ChapterTitle($num,$title);
$this->ChapterBody($file);
}
}
$pdf=new PDF();
$title='20000 Leagues Under the Seas';
$pdf->SetTitle($title);
$pdf->SetAuthor('Jules Verne');
$pdf->PrintChapter(1,'A RUNAWAY REEF','20k_c1.txt');
$pdf->PrintChapter(2,'THE PROS AND CONS','20k_c2.txt');
$pdf->Output();
?>
[Demo]
The key method used is AcceptPageBreak(). It allows to accept or not an automatic page break. By
refusing it and altering the margin and current position, the desired column layout is achieved.
For the rest, not many changes; two properties have been added to the class to save the current column
number and the position where columns begin, and the MultiCell() call specifies a 6 centimeter width.
Tables
This tutorial shows how to make tables easily.
<?php
require('fpdf.php');
//Simple table
function BasicTable($header,$data)
{
//Header
foreach($header as $col)
$this->Cell(40,7,$col,1);
$this->Ln();
//Data
foreach($data as $row)
{
foreach($row as $col)
$this->Cell(40,6,$col,1);
$this->Ln();
}
}
//Better table
function ImprovedTable($header,$data)
{
//Column widths
$w=array(40,35,40,45);
//Header
for($i=0;$i<count($header);$i++)
$this->Cell($w[$i],7,$header[$i],1,0,'C');
$this->Ln();
//Data
foreach($data as $row)
{
$this->Cell($w[0],6,$row[0],'LR');
$this->Cell($w[1],6,$row[1],'LR');
$this->Cell($w[2],6,number_format($row[2]),'LR',0,'R');
$this->Cell($w[3],6,number_format($row[3]),'LR',0,'R');
$this->Ln();
}
//Closure line
$this->Cell(array_sum($w),0,'','T');
}
//Colored table
function FancyTable($header,$data)
{
//Colors, line width and bold font
$this->SetFillColor(255,0,0);
$this->SetTextColor(255);
$this->SetDrawColor(128,0,0);
$this->SetLineWidth(.3);
$this->SetFont('','B');
//Header
$w=array(40,35,40,45);
for($i=0;$i<count($header);$i++)
$this->Cell($w[$i],7,$header[$i],1,0,'C',true);
$this->Ln();
//Color and font restoration
$this->SetFillColor(224,235,255);
$this->SetTextColor(0);
$this->SetFont('');
//Data
$fill=false;
foreach($data as $row)
{
$this->Cell($w[0],6,$row[0],'LR',0,'L',$fill);
$this->Cell($w[1],6,$row[1],'LR',0,'L',$fill);
$this->Cell($w[2],6,number_format($row[2]),'LR',0,'R',$fill);
$this->Cell($w[3],6,number_format($row[3]),'LR',0,'R',$fill);
$this->Ln();
$fill=!$fill;
}
$this->Cell(array_sum($w),0,'','T');
}
}
$pdf=new PDF();
//Column titles
$header=array('Country','Capital','Area (sq km)','Pop. (thousands)');
//Data loading
$data=$pdf->LoadData('countries.txt');
$pdf->SetFont('Arial','',14);
$pdf->AddPage();
$pdf->BasicTable($header,$data);
$pdf->AddPage();
$pdf->ImprovedTable($header,$data);
$pdf->AddPage();
$pdf->FancyTable($header,$data);
$pdf->Output();
?>
[Demo]
A table being just a collection of cells, it is natural to build one from them. The first example is achieved
in the most basic way possible: simple framed cells, all of the same size and left aligned. The result is
rudimentary but very quick to obtain.
The second table brings some improvements: each column has its own width, titles are centered and
figures right aligned. Moreover, horizontal lines have been removed. This is done by means of the
border parameter of the Cell() method, which specifies which sides of the cell must be drawn. Here we
want the left (L) and right (R) ones. It remains the problem of the horizontal line to finish the table. There
are two possibilities: either check for the last line in the loop, in which case we use LRB for the border
parameter; or, as done here, add the line once the loop is over.
The third table is similar to the second one but uses colors. Fill, text and line colors are simply specified.
Alternate coloring for rows is obtained by using alternatively transparent and filled cells.
<?php
require('fpdf.php');
function PDF($orientation='P',$unit='mm',$format='A4')
{
//Call parent constructor
$this->FPDF($orientation,$unit,$format);
//Initialization
$this->B=0;
$this->I=0;
$this->U=0;
$this->HREF='';
}
function WriteHTML($html)
{
//HTML parser
$html=str_replace("\n",' ',$html);
$a=preg_split('/<(.*)>/U',$html,-1,PREG_SPLIT_DELIM_CAPTURE);
foreach($a as $i=>$e)
{
if($i%2==0)
{
//Text
if($this->HREF)
$this->PutLink($this->HREF,$e);
else
$this->Write(5,$e);
}
else
{
//Tag
if($e[0]=='/')
$this->CloseTag(strtoupper(substr($e,1)));
else
{
//Extract attributes
$a2=explode(' ',$e);
$tag=strtoupper(array_shift($a2));
$attr=array();
foreach($a2 as $v)
{
if(preg_match('/([^=]*)=["\']?([^"\']*)/',$v,$a3))
$attr[strtoupper($a3[1])]=$a3[2];
}
$this->OpenTag($tag,$attr);
}
}
}
}
function OpenTag($tag,$attr)
{
//Opening tag
if($tag=='B' || $tag=='I' || $tag=='U')
$this->SetStyle($tag,true);
if($tag=='A')
$this->HREF=$attr['HREF'];
if($tag=='BR')
$this->Ln(5);
}
function CloseTag($tag)
{
//Closing tag
if($tag=='B' || $tag=='I' || $tag=='U')
$this->SetStyle($tag,false);
if($tag=='A')
$this->HREF='';
}
function SetStyle($tag,$enable)
{
//Modify style and select corresponding font
$this->$tag+=($enable ? 1 : -1);
$style='';
foreach(array('B','I','U') as $s)
{
if($this->$s>0)
$style.=$s;
}
$this->SetFont('',$style);
}
function PutLink($URL,$txt)
{
//Put a hyperlink
$this->SetTextColor(0,0,255);
$this->SetStyle('U',true);
$this->Write(5,$txt,$URL);
$this->SetStyle('U',false);
$this->SetTextColor(0);
}
}
$html='You can now easily print text mixing different styles: <b>bold</b>, <i>italic</i>,
<u>underlined</u>, or <b><i><u>all at once</u></i></b>!<br><br>You can also insert links on
text, such as <a href="http://www.fpdf.org">www.fpdf.org</a>, or on an image: click on the logo.';
$pdf=new PDF();
//First page
$pdf->AddPage();
$pdf->SetFont('Arial','',20);
$pdf->Write(5,'To find out what\'s new in this tutorial, click ');
$pdf->SetFont('','U');
$link=$pdf->AddLink();
$pdf->Write(5,'here',$link);
$pdf->SetFont('');
//Second page
$pdf->AddPage();
$pdf->SetLink($link);
$pdf->Image('logo.png',10,12,30,0,'','http://www.fpdf.org');
$pdf->SetLeftMargin(45);
$pdf->SetFontSize(14);
$pdf->WriteHTML($html);
$pdf->Output();
?>
[Demo]
The new method to print text is Write(). It is very close to MultiCell(); the differences are:
● The end of line is at the right margin and the next line begins at the left one
● The current position moves at the end of the text
So it allows to write a chunk of text, alter the font style, then continue from the exact place we left it. On the other hand,
you cannot justify it.
The method is used on the first page to put a link pointing to the second one. The beginning of the sentence is written in
regular style, then we switch to underline and finish it. The link is created with AddLink(), which returns a link identifier.
The identifier is passed as third parameter of Write(). Once the second page is created, we use SetLink() to make the link
point to the beginning of the current page.
Then we put an image with a link on it. An external link points to an URL (HTTP, mailto...). The URL is simply passed as
last parameter of Image().
Finally, the left margin is moved after the image with SetLeftMargin() and some text in HTML format is output. A very
simple HTML parser is used for this, based on regular expressions. Recognized tags are <b>, <i>, <u>, <a> and <br>; the
others are ignored. The parser also makes use of the Write() method. An external link is put the same way as an internal
one (third parameter of Write()). Note that Cell() also allows to put links.
There are two ways to use a new font: embedding it in the PDF or not. When a font is not embedded, it
is searched in the system. The advantage is that the PDF file is lighter; on the other hand, if it is not
available, a substitution font is used. So it is preferable to ensure that the needed font is installed on the
client systems. If the file is to be viewed by a large audience, it is recommended to embed.
For Type1, the first one is theoretically not necessary because the AFM file is usually shipped with the
font. In case you have only a metric file in PFM format, use the convertor available here.
The first step for a TrueType consists in generating the AFM file. A utility exists to do this task: ttf2pt1.
The Windows binary is available here. The command line to use is the following:
The second step consists in generating a PHP file containing all the information needed by FPDF; in
addition, the font file is compressed. To do this, a helper script is provided in the font/makefont/
directory of the package: makefont.php. It contains the following function:
MakeFont(string fontfile, string afmfile [, string enc [, array patch [, string
type]]])
fontfile
afmfile
enc
patch
type
The first parameter is the name of the font file. The extension must be either .ttf or .pfb and determines
the font type. If you own a Type1 font in ASCII format (.pfa), you can convert it to binary format with
t1utils.
If you don't want to embed the font, pass an empty string. In this case, type is given by the type
parameter.
Note: in the case of a font with the same name as a standard one, for instance arial.ttf, it is recommended
to embed. If you don't, some versions of Acrobat will use their own fonts.
The encoding defines the association between a code (from 0 to 255) and a character. The first 128 are
fixed and correspond to ASCII; the following are variable. The encodings are stored in .map files. Those
available are:
● cp1258 (Vietnamese)
● cp874 (Thai)
● ISO-8859-1 (Western Europe)
● ISO-8859-2 (Central Europe)
● ISO-8859-4 (Baltic)
● ISO-8859-5 (Cyrillic)
● ISO-8859-7 (Greek)
● ISO-8859-9 (Turkish)
● ISO-8859-11 (Thai)
● ISO-8859-15 (Western Europe)
● ISO-8859-16 (Central Europe)
● KOI8-R (Russian)
● KOI8-U (Ukrainian)
Of course, the font must contain the characters corresponding to the chosen encoding.
In the particular case of a symbolic font (that is to say which does not contain letters, such as Symbol or
ZapfDingbats), pass an empty string.
The encodings which begin with cp are those used by Windows; Linux systems usually use ISO.
Remark: the standard fonts use cp1252.
The fourth parameter gives the possibility to alter the encoding. Sometimes you may want to add some
characters. For instance, ISO-8859-1 does not contain the euro symbol. To add it at position 164, pass
array(164=>'Euro').
The last parameter is used to give the type of the font in case it is not embedded (that is to say the first
parameter is empty).
After you have called the function (create a new file for this and include makefont.php, or simply add
the call directly inside), a .php file is created, with the same name as the .afm one. You may rename it if
you wish. If the case of embedding, the font file is compressed and gives a second file with .z as
extension (except if the compression function is not available, it requires zlib). You may rename it too,
but in this case you have to alter the variable $file in the .php file accordingly.
Example:
MakeFont('c:\\windows\\fonts\\comic.ttf','comic.afm','cp1252');
Then you have to copy the generated file(s) to the font directory. If the font file could not be
compressed, copy the .ttf or .pfb instead of the .z.
Remark: for TTF fonts, you can generate the files online here instead of doing it manually.
The last step is the most simple. You just need to call the AddFont() method. For instance:
$pdf->AddFont('Comic','','comic.php');
or simply:
$pdf->AddFont('Comic');
And the font is now available (in regular and underlined styles), usable like the others. If we had worked
with Comic Sans MS Bold (comicbd.ttf), we would have put:
$pdf->AddFont('Comic','B','comicbd.php');
Example
Let's now see a small complete example. The font used is Calligrapher, available at www.abstractfonts.
com (a site offering numerous free TrueType fonts). The first step is the generation of the AFM file:
which gives calligra.afm (and calligra.t1a that we can delete). Then we generate the definition file:
<?php
require('font/makefont/makefont.php');
MakeFont('calligra.ttf','calligra.afm');
?>
The euro character is not present in the font (it is too old). Three other characters are missing too, but we
are not interested in them anyway.
We can now copy the two files to the font directory and write the script:
<?php
require('fpdf.php');
$pdf=new FPDF();
$pdf->AddFont('Calligrapher','','calligra.php');
$pdf->AddPage();
$pdf->SetFont('Calligrapher','',35);
$pdf->Cell(0,10,'Enjoy new fonts with FPDF!');
$pdf->Output();
?>
[Demo]
The euro character is not present in all encodings, and is not always placed at the same position:
Encoding Position
cp1250 128
cp1251 136
cp1252 128
cp1253 128
cp1254 128
cp1255 128
cp1257 128
cp1258 128
cp874 128
ISO-8859-1 absent
ISO-8859-2 absent
ISO-8859-4 absent
ISO-8859-5 absent
ISO-8859-7 absent
ISO-8859-9 absent
ISO-8859-11 absent
ISO-8859-15 164
ISO-8859-16 164
KOI8-R absent
KOI8-U absent
ISO-8859-1 is widespread but does not include the euro sign. If you need it, the simplest thing to do is
using cp1252 or ISO-8859-15 instead, which are nearly identical but contain the precious symbol.
As for ISO-8859-2, it is possible to use ISO-8859-16 instead, but it contains many differences. It is
therefore simpler to patch the encoding to add the symbol to it, as explained above. The same is true for
the other encodings.
When a TrueType font is not available in a given style, Windows is able to synthesize it from the regular
version. For instance, there is no Comic Sans MS Italic, but it can be built from Comic Sans MS
Regular. This feature can be used in a PDF file, but unfortunately requires that the regular font be
present in the system (you must not embed it). Here is how to do it:
● Generate the definition file for the regular font without embedding (you may rename it to reflect
the desired style)
● Open it and append to the variable $name a comma followed by the desired style (Italic, Bold
or BoldItalic)
$name='ComicSansMS,Italic';
$pdf->AddFont('Comic','I','comici.php');
Font files are often quite voluminous (more than 100, even 200KB); this is due to the fact that they
contain the characters corresponding to many encodings. zlib compression reduces them but they remain
fairly big. A technique exists to reduce them further. It consists in converting the font to the Type1
format with ttf2pt1 by specifying the encoding you are interested in; all other characters will be
discarded.
For instance, the arial.ttf font shipped with Windows 98 is 267KB (it contains 1296 characters). After
compression it gives 147. Let's convert it to Type1 by keeping only cp1250 characters:
The .map files are located in the font/makefont/ directory of the package. The command produces arial.
pfb and arial.afm. The arial.pfb file is only 35KB, and 30KB after compression.
It is possible to go even further. If you are interested only by a subset of the encoding (you probably
don't need all 217 characters), you can open the .map file and remove the lines you are not interested in.
This will reduce the file size accordingly.
FPDF
FPDF([string orientation [, string unit [, mixed format]]])
Description
This is the class constructor. It allows to set up the page format, the orientation and the unit of measure
used in all methods (except for font sizes).
Parameters
orientation
❍ P or Portrait
❍ L or Landscape
Default value is P.
unit
❍ pt: point
❍ mm: millimeter
❍ cm: centimeter
❍ in: inch
A point equals 1/72 of inch, that is to say about 0.35 mm (an inch being 2.54 cm). This is a very
common unit in typography; font sizes are expressed in that unit.
format
The format used for pages. It can be either one of the following values (case insensitive):
❍ A3
❍ A4
❍ A5
❍ Letter
❍ Legal
or an array containing the width and the height (expressed in the unit given by unit).
Example
AddPage
AddPage([string orientation ,[ mixed format]])
Description
Adds a new page to the document. If a page is already present, the Footer() method is called first to
output the footer. Then the page is added, the current position set to the top-left corner according to the
left and top margins, and Header() is called to display the header.
The font which was set before calling is automatically restored. There is no need to call SetFont() again
if you want to continue with the same font. The same is true for colors and line width.
The origin of the coordinate system is at the top-left corner and increasing ordinates go downwards.
Parameters
orientation
❍ P or Portrait
❍ L or Landscape
format
Page format. It can be either one of the following values (case insensitive):
❍ A3
❍ A4
❍ A5
❍ Letter
❍ Legal
or an array containing the width and the height (expressed in user unit).
See also
SetMargins
SetMargins(float left, float top [, float right])
Description
Defines the left, top and right margins. By default, they equal 1 cm. Call this method to change them.
Parameters
left
Left margin.
top
Top margin.
right
See also
SetFont
SetFont(string family [, string style [, float size]])
Description
Sets the font used to print character strings. It is mandatory to call this method at least once before
printing text or the resulting document would not be valid.
The font can be either a standard one or a font added via the AddFont() method. Standard fonts use
Windows encoding cp1252 (Western Europe).
The method can be called before the first page is created and the font is retained from page to page.
If you just wish to change the current font size, it is simpler to call SetFontSize().
Note: the font metric files must be accessible. They are searched successively in:
● The directory defined by the FPDF_FONTPATH constant (if this constant is defined)
● The font directory located in the directory containing fpdf.php (if it exists)
● The directories accessible through include()
define('FPDF_FONTPATH','/home/www/font/');
require('fpdf.php');
If the file corresponding to the requested font is not found, the error "Could not include font metric file"
is issued.
Parameters
family
Family font. It can be either a name defined by AddFont() or one of the standard families (case
insensitive):
❍ Courier (fixed-width)
❍ Helvetica or Arial (synonymous; sans serif)
❍ Times (serif)
❍ Symbol (symbolic)
❍ ZapfDingbats (symbolic)
It is also possible to pass an empty string. In that case, the current family is retained.
style
or any combination. The default value is regular. Bold and italic styles do not apply to Symbol
and ZapfDingbats.
size
Example
//Times regular 12
$pdf->SetFont('Times');
//Arial bold 14
$pdf->SetFont('Arial','B',14);
//Removes bold
$pdf->SetFont('');
//Times bold, italic and underlined 14
$pdf->SetFont('Times','BIU');
See also
Cell
Cell(float w [, float h [, string txt [, mixed border [, int ln [, string align [,
boolean fill [, mixed link]]]]]]])
Description
Prints a cell (rectangular area) with optional borders, background color and character string. The upper-
left corner of the cell corresponds to the current position. The text can be aligned or centered. After the
call, the current position moves to the right or to the next line. It is possible to put a link on the text.
If automatic page breaking is enabled and the cell goes beyond the limit, a page break is done before
outputting.
Parameters
txt
border
Indicates if borders must be drawn around the cell. The value can be either a number:
❍ 0: no border
❍ 1: frame
or a string containing some or all of the following characters (in any order):
❍ L: left
❍ T: top
❍ R: right
❍ B: bottom
Default value: 0.
ln
Indicates where the current position should go after the call. Possible values are:
❍ 0: to the right
❍ 1: to the beginning of the next line
❍ 2: below
Putting 1 is equivalent to putting 0 and calling Ln() just after. Default value: 0.
align
fill
Indicates if the cell background must be painted (true) or transparent (false). Default value:
false.
link
Example
//Set font
$pdf->SetFont('Arial','B',16);
//Move to 8 cm to the right
$pdf->Cell(80);
//Centered text in a framed 20*10 mm cell and line break
$pdf->Cell(20,10,'Title',1,1,'C');
See also
Ln
Ln([float h])
Description
Performs a line break. The current abscissa goes back to the left margin and the ordinate increases by the
amount passed in parameter.
Parameters
See also
Cell().
Output
string Output([string name, string dest])
Description
Send the document to a given destination: browser, file or string. In the case of browser, the plug-in may
be used (if present) or a download ("Save as" dialog box) may be forced.
The method first calls Close() if necessary to terminate the document.
Parameters
name
The name of the file. If not specified, the document will be sent to the browser (destination I)
with the name doc.pdf.
dest
Destination where to send the document. It can take one of the following values:
❍ I: send the file inline to the browser. The plug-in is used if available. The name given by
name is used when one selects the "Save as" option on the link generating the PDF.
❍ D: send to the browser and force a file download with the name given by name.
❍ F: save to a local file with the name given by name (may include a path).
❍ S: return the document as a string. name is ignored.
See also
Close().
Page 1/2
Title
Page 2/2
Header
Header
Header()
Description
This method is used to render the page header. It is automatically called by AddPage() and should not be
called directly by the application. The implementation in FPDF is empty, so you have to subclass it and
override the method if you want a specific processing.
Example
See also
Footer().
Footer
Footer()
Description
This method is used to render the page footer. It is automatically called by AddPage() and Close() and
should not be called directly by the application. The implementation in FPDF is empty, so you have to
subclass it and override the method if you want a specific processing.
Example
See also
Header().
Image
Image(string file [, float x [, float y [, float w [, float h [, string type [,
mixed link]]]]]])
Description
Puts an image. The size it will take on the page can be specified in different ways:
Supported formats are JPEG, PNG and GIF. The GD extension is required for GIF.
● gray scales
● true colors (24 bits)
● CMYK (32 bits)
● Interlacing
● Alpha channel
For GIFs: in case of an animated GIF, only the first frame is used.
The format can be specified explicitly or inferred from the file extension.
It is possible to put a link on the image.
Remark: if an image is used several times, only one copy is embedded in the file.
Parameters
file
Abscissa of the upper-left corner. If not specified or equal to null, the current abscissa is used.
Ordinate of the upper-left corner. If not specified or equal to null, the current ordinate is used;
moreover, a page break is triggered first if necessary (in case automatic page breaking is enabled)
and, after the call, the current ordinate is moved to the bottom of the image.
Width of the image in the page. If not specified or equal to zero, it is automatically calculated.
Height of the image in the page. If not specified or equal to zero, it is automatically calculated.
type
Image format. Possible values are (case insensitive): JPG, JPEG, PNG and GIF. If not specified, the
type is inferred from the file extension.
link
See also
AddLink().
PageNo
int PageNo()
Description
See also
AliasNbPages().
AliasNbPages
AliasNbPages([string alias])
Description
Defines an alias for the total number of pages. It will be substituted as the document is closed.
Parameters
alias
Example
$pdf=new PDF();
$pdf->AliasNbPages();
See also
PageNo(), Footer().
SetY
SetY(float y)
Description
Moves the current abscissa back to the left margin and sets the ordinate. If the passed value is negative,
it is relative to the bottom of the page.
Parameters
See also
SetAutoPageBreak
SetAutoPageBreak(boolean auto [, float margin])
Description
Enables or disables the automatic page breaking mode. When enabling, the second parameter is the
distance from the bottom of the page that defines the triggering limit. By default, the mode is on and the
margin is 2 cm.
Parameters
auto
margin
See also
The year 1866 was marked by a bizarre development, an unexplained and downright inexplicable phenomenon
that surely no one has forgotten. Without getting into those rumors that upset civilians in the seaports and
deranged the public mind even far inland, it must be said that professional seamen were especially alarmed.
Traders, shipowners, captains of vessels, skippers, and master mariners from Europe and America, naval
officers from every country, and at their heels the various national governments on these two continents, were
all extremely disturbed by the business.
In essence, over a period of time several ships had encountered "an enormous thing" at sea, a long
spindle-shaped object, sometimes giving off a phosphorescent glow, infinitely bigger and faster than any
whale.
The relevant data on this apparition, as recorded in various logbooks, agreed pretty closely as to the structure
of the object or creature in question, its unprecedented speed of movement, its startling locomotive power, and
the unique vitality with which it seemed to be gifted. If it was a cetacean, it exceeded in bulk any whale
previously classified by science. No naturalist, neither Cuvier nor Lacépède, neither Professor Dumeril nor
Professor de Quatrefages, would have accepted the existence of such a monster sight unseen -- specifically,
unseen by their own scientific eyes.
Striking an average of observations taken at different times -- rejecting those timid estimates that gave the
object a length of 200 feet, and ignoring those exaggerated views that saw it as a mile wide and three
long--you could still assert that this phenomenal creature greatly exceeded the dimensions of anything then
known to ichthyologists, if it existed at all.
Now then, it did exist, this was an undeniable fact; and since the human mind dotes on objects of wonder, you
can understand the worldwide excitement caused by this unearthly apparition. As for relegating it to the realm
of fiction, that charge had to be dropped.
In essence, on July 20, 1866, the steamer Governor Higginson, from the Calcutta & Burnach Steam
Navigation Co., encountered this moving mass five miles off the eastern shores of Australia. Captain Baker at
first thought he was in the presence of an unknown reef; he was even about to fix its exact position when two
waterspouts shot out of this inexplicable object and sprang hissing into the air some 150 feet. So, unless this
reef was subject to the intermittent eruptions of a geyser, the Governor Higginson had fair and honest dealings
with some aquatic mammal, until then unknown, that could spurt from its blowholes waterspouts mixed with
air and steam.
Similar events were likewise observed in Pacific seas, on July 23 of the same year, by the Christopher
Columbus from the West India & Pacific Steam Navigation Co. Consequently, this extraordinary cetacean
could transfer itself from one locality to another with startling swiftness, since within an interval of just three
days, the Governor Higginson and the Christopher Columbus had observed it at two positions on the charts
separated by a distance of more than 700 nautical leagues.
Fifteen days later and 2,000 leagues farther, the Helvetia from the Compagnie Nationale and the Shannon
from the Royal Mail line, running on opposite tacks in that part of the Atlantic lying between the United States
and Europe, respectively signaled each other that the monster had been sighted in latitude 42 degrees 15' north
and longitude 60 degrees 35' west of the meridian of Greenwich. From their simultaneous observations, they
were able to estimate the mammal's minimum length at more than 350 English feet; this was because both the
Shannon and the Helvetia were of smaller dimensions, although each measured 100 meters stem to stern. Now
then, the biggest whales, those rorqual whales that frequent the waterways of the Aleutian Islands, have never
exceeded a length of 56 meters--if they reach even that.
One after another, reports arrived that would profoundly affect public opinion: new observations taken by the
transatlantic liner Pereire, the Inman line's Etna running afoul of the monster, an official report drawn up by
officers on the French frigate Normandy, dead-earnest reckonings obtained by the general staff of Commodore
Fitz-James aboard the Lord Clyde. In lighthearted countries, people joked about this phenomenon, but such
serious, practical countries as England, America, and Germany were deeply concerned.
Page 1
20000 Leagues Under the Seas
In every big city the monster was the latest rage; they sang about it in the coffee houses, they ridiculed it in the
newspapers, they dramatized it in the theaters. The tabloids found it a fine opportunity for hatching all sorts of
hoaxes. In those newspapers short of copy, you saw the reappearance of every gigantic imaginary creature,
from "Moby Dick," that dreadful white whale from the High Arctic regions, to the stupendous kraken whose
tentacles could entwine a 500-ton craft and drag it into the ocean depths. They even reprinted reports from
ancient times: the views of Aristotle and Pliny accepting the existence of such monsters, then the Norwegian
stories of Bishop Pontoppidan, the narratives of Paul Egede, and finally the reports of Captain Harrington --
whose good faith is above suspicion--in which he claims he saw, while aboard the Castilian in 1857, one of
those enormous serpents that, until then, had frequented only the seas of France's old extremist newspaper,
The Constitutionalist.
(end of excerpt)
Page 2
20000 Leagues Under the Seas
During the period in which these developments were occurring, I had returned from a scientific undertaking
organized to explore the Nebraska badlands in the United States. In my capacity as Assistant Professor at the
Paris Museum of Natural History, I had been attached to this expedition by the French government. After
spending six months in Nebraska, I arrived in New York laden with valuable collections near the end of
March. My departure for France was set for early May. In the meantime, then, I was busy classifying my
mineralogical, botanical, and zoological treasures when that incident took place with the Scotia.
I was perfectly abreast of this question, which was the big news of the day, and how could I not have been? I
had read and reread every American and European newspaper without being any farther along. This mystery
puzzled me. Finding it impossible to form any views, I drifted from one extreme to the other. Something was
out there, that much was certain, and any doubting Thomas was invited to place his finger on the Scotia's
wound.
When I arrived in New York, the question was at the boiling point. The hypothesis of a drifting islet or an
elusive reef, put forward by people not quite in their right minds, was completely eliminated. And indeed,
unless this reef had an engine in its belly, how could it move about with such prodigious speed?
Also discredited was the idea of a floating hull or some other enormous wreckage, and again because of this
speed of movement.
So only two possible solutions to the question were left, creating two very distinct groups of supporters: on
one side, those favoring a monster of colossal strength; on the other, those favoring an "underwater boat" of
tremendous motor power.
Now then, although the latter hypothesis was completely admissible, it couldn't stand up to inquiries
conducted in both the New World and the Old. That a private individual had such a mechanism at his disposal
was less than probable. Where and when had he built it, and how could he have built it in secret?
Only some government could own such an engine of destruction, and in these disaster-filled times, when men
tax their ingenuity to build increasingly powerful aggressive weapons, it was possible that, unknown to the
rest of the world, some nation could have been testing such a fearsome machine. The Chassepot rifle led to the
torpedo, and the torpedo has led to this underwater battering ram, which in turn will lead to the world putting
its foot down. At least I hope it will.
But this hypothesis of a war machine collapsed in the face of formal denials from the various governments.
Since the public interest was at stake and transoceanic travel was suffering, the sincerity of these governments
could not be doubted. Besides, how could the assembly of this underwater boat have escaped public notice?
Keeping a secret under such circumstances would be difficult enough for an individual, and certainly
impossible for a nation whose every move is under constant surveillance by rival powers.
So, after inquiries conducted in England, France, Russia, Prussia, Spain, Italy, America, and even Turkey, the
hypothesis of an underwater Monitor was ultimately rejected.
After I arrived in New York, several people did me the honor of consulting me on the phenomenon in
question. In France I had published a two-volume work, in quarto, entitled The Mysteries of the Great Ocean
Depths. Well received in scholarly circles, this book had established me as a specialist in this pretty obscure
field of natural history. My views were in demand. As long as I could deny the reality of the business, I
confined myself to a flat "no comment." But soon, pinned to the wall, I had to explain myself straight out. And
in this vein, "the honorable Pierre Aronnax, Professor at the Paris Museum," was summoned by The New
York Herald to formulate his views no matter what.
I complied. Since I could no longer hold my tongue, I let it wag. I discussed the question in its every aspect,
both political and scientific, and this is an excerpt from the well-padded article I published in the issue of April
30.
"Therefore," I wrote, "after examining these different hypotheses one by one, we are forced, every other
supposition having been refuted, to accept the existence of an extremely powerful marine animal.
Page 3
20000 Leagues Under the Seas
"The deepest parts of the ocean are totally unknown to us. No soundings have been able to reach them. What
goes on in those distant depths? What creatures inhabit, or could inhabit, those regions twelve or fifteen miles
beneath the surface of the water? What is the constitution of these animals? It's almost beyond conjecture.
"However, the solution to this problem submitted to me can take the form of a choice between two
alternatives.
"Either we know every variety of creature populating our planet, or we do not.
"If we do not know every one of them, if nature still keeps ichthyological secrets from us, nothing is more
admissible than to accept the existence of fish or cetaceans of new species or even new genera, animals with a
basically 'cast-iron' constitution that inhabit strata beyond the reach of our soundings, and which some
development or other, an urge or a whim if you prefer, can bring to the upper level of the ocean for long
intervals.
"If, on the other hand, we do know every living species, we must look for the animal in question among those
marine creatures already cataloged, and in this event I would be inclined to accept the existence of a giant
narwhale.
"The common narwhale, or sea unicorn, often reaches a length of sixty feet. Increase its dimensions fivefold or
even tenfold, then give this cetacean a strength in proportion to its size while enlarging its offensive weapons,
and you have the animal we're looking for. It would have the proportions determined by the officers of the
Shannon, the instrument needed to perforate the Scotia, and the power to pierce a steamer's hull.
"In essence, the narwhale is armed with a sort of ivory sword, or lance, as certain naturalists have expressed it.
It's a king-sized tooth as hard as steel. Some of these teeth have been found buried in the bodies of baleen
whales, which the narwhale attacks with invariable success. Others have been wrenched, not without
difficulty, from the undersides of vessels that narwhales have pierced clean through, as a gimlet pierces a wine
barrel. The museum at the Faculty of Medicine in Paris owns one of these tusks with a length of 2.25 meters
and a width at its base of forty-eight centimeters!
"All right then! Imagine this weapon to be ten times stronger and the animal ten times more powerful, launch
it at a speed of twenty miles per hour, multiply its mass times its velocity, and you get just the collision we
need to cause the specified catastrophe.
"So, until information becomes more abundant, I plump for a sea unicorn of colossal dimensions, no longer
armed with a mere lance but with an actual spur, like ironclad frigates or those warships called 'rams,' whose
mass and motor power it would possess simultaneously.
"This inexplicable phenomenon is thus explained away--unless it's something else entirely, which, despite
everything that has been sighted, studied, explored and experienced, is still possible!"
(end of excerpt)
Page 4
GetStringWidth
GetStringWidth
float GetStringWidth(string s)
Description
Parameters
SetDrawColor
SetDrawColor(int r [, int g, int b])
Description
Defines the color used for all drawing operations (lines, rectangles and cell borders). It can be expressed
in RGB components or gray scale. The method can be called before the first page is created and the
value is retained from page to page.
Parameters
If g et b are given, red component; if not, indicates the gray level. Value between 0 and 255.
See also
SetFillColor
SetFillColor(int r [, int g, int b])
Description
Defines the color used for all filling operations (filled rectangles and cell backgrounds). It can be
expressed in RGB components or gray scale. The method can be called before the first page is created
and the value is retained from page to page.
Parameters
If g and b are given, red component; if not, indicates the gray level. Value between 0 and 255.
See also
SetTextColor
SetTextColor(int r [, int g, int b])
Description
Defines the color used for text. It can be expressed in RGB components or gray scale. The method can
be called before the first page is created and the value is retained from page to page.
Parameters
If g et b are given, red component; if not, indicates the gray level. Value between 0 and 255.
See also
SetLineWidth
SetLineWidth(float width)
Description
Defines the line width. By default, the value equals 0.2 mm. The method can be called before the first
page is created and the value is retained from page to page.
Parameters
width
The width.
See also
MultiCell
MultiCell(float w, float h, string txt [, mixed border [, string align [, boolean
fill]]])
Description
This method allows printing text with line breaks. They can be automatic (as soon as the text reaches the
right border of the cell) or explicit (via the \n character). As many cells as necessary are output, one
below the other.
Text can be aligned, centered or justified. The cell block can be framed and the background painted.
Parameters
Height of cells.
txt
String to print.
border
Indicates if borders must be drawn around the cell block. The value can be either a number:
❍ 0: no border
❍ 1: frame
or a string containing some or all of the following characters (in any order):
❍ L: left
❍ T: top
❍ R: right
❍ B: bottom
Default value: 0.
align
❍ L: left alignment
❍ C: center
❍ R: right alignment
❍ J: justification (default value)
fill
Indicates if the cell background must be painted (true) or transparent (false). Default value:
false.
See also
SetTitle
SetTitle(string title [, boolean isUTF8])
Description
Parameters
title
The title.
isUTF8
See also
SetAuthor
SetAuthor(string author [, boolean isUTF8])
Description
Parameters
author
isUTF8
See also
The year 1866 was marked by a observations taken at different Navigation Co. Consequently,
bizarre development, an times -- rejecting those timid this extraordinary cetacean could
unexplained and downright estimates that gave the object a transfer itself from one locality to
inexplicable phenomenon that length of 200 feet, and ignoring another with startling swiftness,
surely no one has forgotten. those exaggerated views that saw since within an interval of just
Without getting into those rumors it as a mile wide and three three days, the Governor
that upset civilians in the seaports long--you could still assert that Higginson and the Christopher
and deranged the public mind this phenomenal creature greatly Columbus had observed it at two
even far inland, it must be said exceeded the dimensions of positions on the charts separated
that professional seamen were anything then known to by a distance of more than 700
especially alarmed. Traders, ichthyologists, if it existed at all. nautical leagues.
shipowners, captains of vessels, Now then, it did exist, this was an Fifteen days later and 2,000
skippers, and master mariners undeniable fact; and since the leagues farther, the Helvetia from
from Europe and America, naval human mind dotes on objects of the Compagnie Nationale and the
officers from every country, and wonder, you can understand the Shannon from the Royal Mail
at their heels the various national worldwide excitement caused by line, running on opposite tacks in
governments on these two this unearthly apparition. As for that part of the Atlantic lying
continents, were all extremely relegating it to the realm of between the United States and
disturbed by the business. fiction, that charge had to be Europe, respectively signaled
In essence, over a period of time dropped. each other that the monster had
several ships had encountered "an In essence, on July 20, 1866, the been sighted in latitude 42
enormous thing" at sea, a long steamer Governor Higginson, degrees 15' north and longitude
spindle-shaped object, sometimes from the Calcutta & Burnach 60 degrees 35' west of the
giving off a phosphorescent glow, Steam Navigation Co., meridian of Greenwich. From
infinitely bigger and faster than encountered this moving mass their simultaneous observations,
any whale. five miles off the eastern shores they were able to estimate the
The relevant data on this of Australia. Captain Baker at mammal's minimum length at
apparition, as recorded in various first thought he was in the more than 350 English feet; this
logbooks, agreed pretty closely as presence of an unknown reef; he was because both the Shannon
to the structure of the object or was even about to fix its exact and the Helvetia were of smaller
creature in question, its position when two waterspouts dimensions, although each
unprecedented speed of shot out of this inexplicable measured 100 meters stem to
movement, its startling object and sprang hissing into the stern. Now then, the biggest
locomotive power, and the unique air some 150 feet. So, unless this whales, those rorqual whales that
vitality with which it seemed to reef was subject to the frequent the waterways of the
be gifted. If it was a cetacean, it intermittent eruptions of a geyser, Aleutian Islands, have never
exceeded in bulk any whale the Governor Higginson had fair exceeded a length of 56 meters--if
previously classified by science. and honest dealings with some they reach even that.
No naturalist, neither Cuvier nor aquatic mammal, until then One after another, reports arrived
Lacépède, neither Professor unknown, that could spurt from that would profoundly affect
Dumeril nor Professor de its blowholes waterspouts mixed public opinion: new observations
Quatrefages, would have with air and steam. taken by the transatlantic liner
accepted the existence of such a Similar events were likewise Pereire, the Inman line's Etna
monster sight unseen -- observed in Pacific seas, on July running afoul of the monster, an
specifically, unseen by their own 23 of the same year, by the official report drawn up by
scientific eyes. Christopher Columbus from the officers on the French frigate
Striking an average of West India & Pacific Steam Normandy, dead-earnest
Page 1
20000 Leagues Under the Seas
(end of excerpt)
Page 2
20000 Leagues Under the Seas
During the period in which these enormous wreckage, and again have escaped public notice?
developments were occurring, I because of this speed of Keeping a secret under such
had returned from a scientific movement. circumstances would be difficult
undertaking organized to explore So only two possible solutions to enough for an individual, and
the Nebraska badlands in the the question were left, creating certainly impossible for a nation
United States. In my capacity as two very distinct groups of whose every move is under
Assistant Professor at the Paris supporters: on one side, those constant surveillance by rival
Museum of Natural History, I had favoring a monster of colossal powers.
been attached to this expedition strength; on the other, those So, after inquiries conducted in
by the French government. After favoring an "underwater boat" of England, France, Russia, Prussia,
spending six months in Nebraska, tremendous motor power. Spain, Italy, America, and even
I arrived in New York laden with Now then, although the latter Turkey, the hypothesis of an
valuable collections near the end hypothesis was completely underwater Monitor was
of March. My departure for admissible, it couldn't stand up to ultimately rejected.
France was set for early May. In inquiries conducted in both the After I arrived in New York,
the meantime, then, I was busy New World and the Old. That a several people did me the honor
classifying my mineralogical, private individual had such a of consulting me on the
botanical, and zoological mechanism at his disposal was phenomenon in question. In
treasures when that incident took less than probable. Where and France I had published a
place with the Scotia. when had he built it, and how two-volume work, in quarto,
I was perfectly abreast of this could he have built it in secret? entitled The Mysteries of the
question, which was the big news Only some government could Great Ocean Depths. Well
of the day, and how could I not own such an engine of received in scholarly circles, this
have been? I had read and reread destruction, and in these book had established me as a
every American and European disaster-filled times, when men specialist in this pretty obscure
newspaper without being any tax their ingenuity to build field of natural history. My views
farther along. This mystery increasingly powerful aggressive were in demand. As long as I
puzzled me. Finding it impossible weapons, it was possible that, could deny the reality of the
to form any views, I drifted from unknown to the rest of the world, business, I confined myself to a
one extreme to the other. some nation could have been flat "no comment." But soon,
Something was out there, that testing such a fearsome machine. pinned to the wall, I had to
much was certain, and any The Chassepot rifle led to the explain myself straight out. And
doubting Thomas was invited to torpedo, and the torpedo has led in this vein, "the honorable Pierre
place his finger on the Scotia's to this underwater battering ram, Aronnax, Professor at the Paris
wound. which in turn will lead to the Museum," was summoned by The
When I arrived in New York, the world putting its foot down. At New York Herald to formulate
question was at the boiling point. least I hope it will. his views no matter what.
The hypothesis of a drifting islet But this hypothesis of a war I complied. Since I could no
or an elusive reef, put forward by machine collapsed in the face of longer hold my tongue, I let it
people not quite in their right formal denials from the various wag. I discussed the question in
minds, was completely governments. Since the public its every aspect, both political and
eliminated. And indeed, unless interest was at stake and scientific, and this is an excerpt
this reef had an engine in its transoceanic travel was suffering, from the well-padded article I
belly, how could it move about the sincerity of these published in the issue of April 30.
with such prodigious speed? governments could not be
Also discredited was the idea of a doubted. Besides, how could the "Therefore," I wrote, "after
floating hull or some other assembly of this underwater boat examining these different
Page 3
20000 Leagues Under the Seas
hypotheses one by one, we are fivefold or even tenfold, then give thus explained away--unless it's
forced, every other supposition this cetacean a strength in something else entirely, which,
having been refuted, to accept the proportion to its size while despite everything that has been
existence of an extremely enlarging its offensive weapons, sighted, studied, explored and
powerful marine animal. and you have the animal we're experienced, is still possible!"
"The deepest parts of the ocean looking for. It would have the
are totally unknown to us. No proportions determined by the (end of excerpt)
soundings have been able to reach officers of the Shannon, the
them. What goes on in those instrument needed to perforate
distant depths? What creatures the Scotia, and the power to
inhabit, or could inhabit, those pierce a steamer's hull.
regions twelve or fifteen miles "In essence, the narwhale is
beneath the surface of the water? armed with a sort of ivory sword,
What is the constitution of these or lance, as certain naturalists
animals? It's almost beyond have expressed it. It's a king-sized
conjecture. tooth as hard as steel. Some of
"However, the solution to this these teeth have been found
problem submitted to me can take buried in the bodies of baleen
the form of a choice between two whales, which the narwhale
alternatives. attacks with invariable success.
"Either we know every variety of Others have been wrenched, not
creature populating our planet, or without difficulty, from the
we do not. undersides of vessels that
"If we do not know every one of narwhales have pierced clean
them, if nature still keeps through, as a gimlet pierces a
ichthyological secrets from us, wine barrel. The museum at the
nothing is more admissible than Faculty of Medicine in Paris
to accept the existence of fish or owns one of these tusks with a
cetaceans of new species or even length of 2.25 meters and a width
new genera, animals with a at its base of forty-eight
basically 'cast-iron' constitution centimeters!
that inhabit strata beyond the "All right then! Imagine this
reach of our soundings, and weapon to be ten times stronger
which some development or and the animal ten times more
other, an urge or a whim if you powerful, launch it at a speed of
prefer, can bring to the upper twenty miles per hour, multiply
level of the ocean for long its mass times its velocity, and
intervals. you get just the collision we need
"If, on the other hand, we do to cause the specified catastrophe.
know every living species, we "So, until information becomes
must look for the animal in more abundant, I plump for a sea
question among those marine unicorn of colossal dimensions,
creatures already cataloged, and no longer armed with a mere
in this event I would be inclined lance but with an actual spur, like
to accept the existence of a giant ironclad frigates or those
narwhale. warships called 'rams,' whose
"The common narwhale, or sea mass and motor power it would
unicorn, often reaches a length of possess simultaneously.
sixty feet. Increase its dimensions "This inexplicable phenomenon is
Page 4
AcceptPageBreak
AcceptPageBreak
boolean AcceptPageBreak()
Description
Whenever a page break condition is met, the method is called, and the break is issued or not depending
on the returned value. The default implementation returns a value according to the mode selected by
SetAutoPageBreak().
This method is called automatically and should not be called directly by the application.
Example
function SetCol($col)
{
//Move position to a column
$this->col=$col;
$x=10+$col*65;
$this->SetLeftMargin($x);
$this->SetX($x);
}
function AcceptPageBreak()
{
if($this->col<2)
{
//Go to next column
$this->SetCol($this->col+1);
$this->SetY(10);
return false;
}
else
{
//Go back to first column and issue page break
$this->SetCol(0);
return true;
}
}
}
$pdf=new PDF();
$pdf->AddPage();
$pdf->SetFont('Arial','',12);
for($i=1;$i<=300;$i++)
$pdf->Cell(0,5,"Line $i",0,1);
$pdf->Output();
See also
SetAutoPageBreak().
Write
Write(float h, string txt [, mixed link])
Description
This method prints text from the current position. When the right margin is reached (or the \n character
is met) a line break occurs and text continues from the left margin. Upon method exit, the current
position is left just at the end of the text.
It is possible to put a link on the text.
Parameters
Line height.
txt
String to print.
link
Example
See also
AddLink
int AddLink()
Description
Creates a new internal link and returns its identifier. An internal link is a clickable area which directs to
another place within the document.
The identifier can then be passed to Cell(), Write(), Image() or Link(). The destination is defined with
SetLink().
See also
SetLink
SetLink(int link [, float y [, int page]])
Description
Parameters
link
Ordinate of target position; -1 indicates the current position. The default value is 0 (top of page).
page
Number of target page; -1 indicates the current page. This is the default value.
See also
AddLink().
SetLeftMargin
SetLeftMargin(float margin)
Description
Defines the left margin. The method can be called before creating the first page.
If the current abscissa gets out of page, it is brought back to the margin.
Parameters
margin
The margin.
See also
AddFont
AddFont(string family [, string style [, string file]])
Description
Imports a TrueType or Type1 font and makes it available. It is necessary to generate a font definition file
first with the makefont.php utility.
The definition file (and the font file itself when embedding) must be present in the font directory. If it is
not found, the error "Could not include font definition file" is generated.
Parameters
family
Font family. The name can be chosen arbitrarily. If it is a standard family name, it will override
the corresponding font.
style
file
Example
$pdf->AddFont('Comic','I');
is equivalent to:
$pdf->AddFont('Comic','I','comici.php');
See also
SetFont().