jspdf-customfonts

0.0.4-rc.4 • Public • Published

jsPDF-CustomFonts-support

Build Status License: MIT

JsPDF is an open source that loads JavaScript in an HTML5 environment and creates a pdf document.

The current version does not support Custom Fonts. I will try to implement this feature.

Demo

It's on the GitHub Pages.

Current Version

Version 0.0.4

jsPDF libary

I do not claim to be the author of the jsPDF library, this code simply adds preliminary custom fonts support.

Version History

0.0.1 Initial proof of concept

0.0.2 Support multiline text

0.0.3 Refactor multiline text

0.0.4 Make into a plugin

Install

Download and include jspdf.customfonts.min.js.

You can also get the plugin with a package manager:

  • npm install jspdf-customfonts

Getting Started

This document will walk you through the basics of jsPDF and will show you how to create PDF files in the browser.

To begin with the default configuration, you should include 3 files:

  • https://unpkg.com/jspdf@latest/dist/jspdf.min.js,
  • dist/jspdf.customfonts.min.js,
  • dist/default_vfs.js - default vfs font definition (it contains 1 Font)
    • however you can use custom fonts according to the following detailed instructions :
      1. Run npm install
      2. Copy your fonts into the fonts subdirectory.
      3. Run node makeFonts.js to create a new dist/default_vfs.js.
      4. Include your new dist/default_vfs.js file in your code.
<!DOCTYPE html>
<html>
 
<head>
    <meta http-equiv="Content-type" content="text/html; charset=utf-8" />
    <title>jsPDF customfonts example</title>
    <script src="https://unpkg.com/jspdf@latest/dist/jspdf.min.js"></script> 
    <script src="dist/jspdf.customfonts.min.js"></script> 
    <script src="dist/default_vfs.js"></script> 
</head>
<body>
...

addFileToVFS Method

doc.addFileToVFS(fileName, Base64content);

addFont Method

doc.addFont(fileName, fontName, fontStyle);

Example Code

var doc = new jsPDF();
 
doc.addFont('NotoSansCJKjp-Regular.ttf', 'NotoSansCJKjp', 'normal');
 
doc.setFont('NotoSansCJKjp');
doc.text(15, 30, 'こんにちは。はじめまして。');
 
//multi-lines Test
var paragraph = '相次いで廃止された寝台列車に代わり、いまや夜間の移動手段として主力になりつつある夜行バス。「安い」「寝ながら移動できる」などのメリットを生かすため、運行ダイヤはどのように組まれているのでしょうか。夜遅く出て、朝早く着くというメリット夜行バスを使うメリットといえば、各種アンケートでもいちばん多い回答の「安い」以外に、';
var lines = doc.splitTextToSize(paragraph, 150);
doc.text(15, 60, lines);
 
doc.save('custom_fonts.pdf');
 

License

MIT

Readme

Keywords

Package Sidebar

Install

npm i jspdf-customfonts

Weekly Downloads

569

Version

0.0.4-rc.4

License

MIT

Unpacked Size

110 kB

Total Files

6

Last publish

Collaborators

  • sphilee