Update README.md

This commit is contained in:
Sebastián Katzer 2016-08-03 17:38:33 +02:00
parent 7d38b4e354
commit 6b5c51e4b1

362
README.md
View File

@ -1,127 +1,76 @@
<p align="right"> <p align="left">
<b><a href="#">master</a></b> <b><a href="https://github.com/katzer/cordova-plugin-printer/blob/example/README.md">SAMPLE APP</a> :point_right:</b>
<span>&nbsp;</span>
<a href="https://github.com/katzer/cordova-plugin-printer/tree/google-cloud-print">v0.6</a>
<span>&nbsp;</span>
<a href="https://github.com/katzer/cordova-plugin-printer/tree/network-printer">v0.5</a>
<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>
<i><a href="https://github.com/katzer/cordova-plugin-printer/tree/example">EXAMPLE :point_right:</a></i>
</p> </p>
Cordova Print Plugin Cordova Print Plugin
==================== ====================
[Cordova][cordova] plugin to print HTML documents using [__AirPrint__][AirPrint] and [__Android Printing Framework__][APF]. Plugin for the [Cordova][cordova] framework to print HTML from iOS, Android and Windows Universal apps.
:bangbang:&nbsp;__Choose the right branch for you!__&nbsp;:bangbang: <p align="center">
<img width="23.8%" src="https://github.com/katzer/cordova-plugin-printer/blob/example/images/print-ios.png"></img>
The plugin provides multiple branches to support different printer types and android versions while _AirPrint_ is supported with each one. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
<img width="26.8%" src="https://github.com/katzer/cordova-plugin-printer/blob/example/images/print-windows.png"></img>
- [master Branch][master_branch] for iOS and Android >= 4.4 (>= v0.7.x) &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
- [google-cloud-print Branch][google-cloud-print_branch] for Android <= 4.3 (~> v0.6.x) <img width="23.8%" src="https://github.com/katzer/cordova-plugin-printer/blob/example/images/print-android.png"></img>
- __Deprecated__ [network-printer Branch][network-printer_branch] for Android <= 4.3 (<= v0.5.x) </p>
### About Apple AirPrint ### About Apple AirPrint
AirPrint is an Apple™ technology that helps you create full-quality printed output without the need to download or install drivers. AirPrint is built in to many printer models from most popular printer manufacturers. Just select an AirPrint printer on your local network to print from your favorite iOS or OS X app.<br> AirPrint is an Apple™ technology that helps you create full-quality printed output without the need to download or install drivers. AirPrint is built in to many printer models from most popular printer manufacturers. Just select an AirPrint printer on your local network to print from your favorite iOS or OS X app.
AirPrint printers are available for these devices when using the latest version of iOS available for them:
- iPad (all models)
- iPhone (3GS or later)
- iPod touch (3rd generation or later)
<img src="http://static1.businessinsider.com/image/4cf67b8149e2aeb00b020000/only-12-printers-work-with-apples-airprint-heres-the-list.jpg" /> See [Drawing and Printing Guide for iOS][ios_guide] for detailed informations.
### Android Printing Framework ### About Android Printing Framework
Printing in __Android 4.4__ and later is provided by the Printing framework. By default, most Android devices have print service plugins installed to enable printing using the Google Cloud Print and Google Drive services. Print service plugins from other printer manufactures are available through the App Store though the Google Cloud Print service plugin can also be used to print from an Android device to just about any printer type and model.<br> Starting with _KitKat_, most Android devices have print service plugins installed to enable printing using the Google Cloud Print and Google Drive services. Print service plugins from other printer manufactures are available through the App Store though the Google Cloud Print service plugin can also be used to print from an Android device to just about any printer type and model.<br>
In addition to supporting physical printers, it is also possible to save printed output to your Google Drive account or locally as a PDF file on the Android device. In addition to supporting physical printers, it is also possible to save printed output to your Google Drive account or locally as a PDF file on the Android device.
<img src="http://androidtopnews.com/wp-content/uploads/2013/10/46888__android-4.4-kitkat-official-4.jpg" /> See [Building Apps with Multimedia for Android][android_guide] for detailed informations.
### Supported Printers
Printing is supported on AirPrint- and Google Cloud Print-enabled printers or from Android devices to compatible network printers over Wi-Fi. The following pages contain more information:
- AirPrint-enabled printers: http://www.apple.com/ipad/features/airprint.html
- Enabling AirPrint on your computer: http://reviews.cnet.com/8301-19512_7-20023976-233.html, or http://www.ecamm.com/mac/printopia/
- Google Cloud-ready printers: http://www.google.com/cloudprint/learn/printers.html
- Connect network printers with Google Cloud Print: https://support.google.com/cloudprint/answer/1686197?rd=1
- Printing with the Android Printing Framework: http://www.techotopia.com/index.php/Printing_with_the_Android_Printing_Framework
### Plugin's Purpose
This Cordova plugin serves as a platform independent JavaScript bridge to call the underlying native SDKs.
## Supported Platforms ## Supported Platforms
- **iOS** *(Print from iOS devices to AirPrint compatible printers)*<br> - iOS 8 or up
See [Drawing and Printing Guide for iOS][ios_guide] for detailed informations and screenshots. - Android KitKat or up
- Universal Windows Platform
- **Android KitKat** *(Print from Android devices to compatible printers over Wi-Fi or cloud-hosted services such as Google Cloud Print)*
## Installation ## Installation
The plugin can either be installed from git repository, from local file system through the [Command-line Interface][CLI]. Or cloud based through [PhoneGap Build][PGB]. Install the latest version:
cordova plugin add cordova-plugin-printer
Or a specific version:
cordova plugin add cordova-plugin-printer@VERSION
Or the latest dev version:
### Local development environment
From master:
```bash
# ~~ from master ~~
cordova plugin add https://github.com/katzer/cordova-plugin-printer.git cordova plugin add https://github.com/katzer/cordova-plugin-printer.git
```
from a local folder:
```bash
# ~~ local folder ~~
cordova plugin add de.appplant.cordova.plugin.printer --searchpath path/to/plugin
```
or to use the last stable version:
```bash
# ~~ stable version ~~
cordova plugin add de.appplant.cordova.plugin.printer
```
### PhoneGap Build Or a custom version:
Add the following xml to your config.xml to always use the latest version of this plugin:
```xml
<gap:plugin name="de.appplant.cordova.plugin.printer" />
```
or to use an specific version:
```xml
<gap:plugin name="de.appplant.cordova.plugin.printer" version="0.7.0" />
```
More informations can be found [here][PGB_plugin].
### Removing the Plugin cordova plugin add cordova-plugin-printer --searchpath path/to/plugin
Through the [Command-line Interface][CLI]:
```bash And then execute:
cordova plugin rm de.appplant.cordova.plugin.printer
``` cordova build
## ChangeLog ## ChangeLog
#### Version 0.7.1 (23.04.2015) #### Version 0.7.2 (not yet released)
- [bugfix:] `isAvailable` does not block the main thread anymore. - __TODO__
- [bugfix:] iPad+iOS8 incompatibility (Thanks to __zmagyar__)
- [enhancement:] Print-View positioning on iPad
- [enhancement:] Send direct to printer when printerId: is specified.
#### Version 0.7.0 (12.09.2014) See [CHANGELOG.md][changelog] to get the full changelog for the plugin.
- Android Printing Framework support
- [__change__:] Renamed `isServiceAvailable` to `isAvailable`
- [enhancement:] New print options like `name`, `landscape` or `duplex`
- [enhancement:] Ability to print remote content via URI
- [enhancement:] Callback support
- [bugfix:] `isAvailable` does not block the main thread anymore.
#### Further informations
- See [CHANGELOG.md][changelog] to get the full changelog for the plugin.
## Using the plugin ## Usage
The plugin creates the object `cordova.plugins.printer` with the following methods: The plugin creates the object `cordova.plugins.printer` with the following methods:
1. [printer.isAvailable][available] - [check][check]
2. [printer.print][print] - [pick][pick]
3. [printer.print][printerPicker] (iOS only) - [print][print]
### Plugin initialization __Note:__ The plugin and its methods are not available before the *deviceready* event has been fired.
The plugin and its methods are not available before the *deviceready* event has been fired.
```javascript ```javascript
document.addEventListener('deviceready', function () { document.addEventListener('deviceready', function () {
@ -129,179 +78,127 @@ document.addEventListener('deviceready', function () {
}, false); }, false);
``` ```
### Find out if printing is available on the device ### Check printer
The device his printing capabilities can be reviewed through the `printer.isAvailable` interface. The device his printing capabilities can be reviewed through the `printer.check` interface. Use this function to hide print functionality from users who will be unable to use it.
You can use this function to hide print functionality from users who will be unable to use it.<br>
The method takes a callback function, passed to which is a boolean property. Optionally you can assign the scope in which the callback will be executed as a second parameter (default to *window*).
__Note:__ Printing is only available on devices capable of multi-tasking (iPhone 3GS, iPhone 4 etc.) running iOS 4.2 or later or Android KitKat and above.<br>
```javascript ```javascript
/** /**
* Checks if the printer service is avaible (iOS) * Checks if the printer service is avaible (iOS)
* or if connected to the Internet (Android). * or if printer services are installed and enabled (Android).
* *
* @param {Function} callback * @param {Function} callback
* A callback function * A callback function
* @param {Object?} scope * @param {Object} scope
* The scope of the callback (default: window) * Optional scope of the callback
* * Defaults to: window
* @return {Boolean}
*/ */
cordova.plugins.printer.isAvailable( cordova.plugins.printer.check(function (avail, count) {
function (isAvailable) { alert(avail ? 'Found ' + count + ' services' : 'No');
alert(isAvailable ? 'Service is available' : 'Service NOT available'); });
}
);
``` ```
### Send content to a printer ### Pick a printer
Content can be send to a printer through the `printer.print` interface.<br> Displays a system interface allowing the user to select an available printer.
The method takes a string or a HTML DOM node. The string can contain HTML content or an URI pointing to another web page. Optional parameters allows to specify the name of the document and a callback. The callback will be called if the user cancels or completes the print job. To speak with a printer directly you need to know the network address by picking them before via `printer.pick`.
#### Available Options Note that picking a printer is not supported for windows platform.
| Name | Description | Type | Support |
| ---- | ----------- |:----:| -------:|
| name | The name of the print job and of the document | String | all |
| printerId| The network URL to the printer. | String | iOS |
| duplex | Specifies the duplex mode to use for the print job.<br>Either double-sided (duplex:true) or single-sided (duplex:false).<br>Double-sided by default. | Boolean | iOS |
| landscape| The orientation of the printed content, portrait or landscape.<br>_Portrait_ by default. | Boolean | all |
| graystyle | If your application only prints black text, setting this property to _true_ can result in better performance in many cases.<br>_False_ by default. | Boolean | all |
| bounds | The Size and position of the print view | Array | iPad |
#### Further informations
- See the [isAvailable][available] method to find out if printing is available on the device.
- All CSS rules needs to be embedded or accessible via absolute URLs in order to print out HTML encoded content.
- The string can contain HTML content or an URI pointing to another web page.
- See the [examples][examples] to get an overview on how to use the plugin.
```javascript ```javascript
/** /**
* Sends the content to the Google Cloud Print service. * Displays system interface for selecting a printer.
*
* @param {Function} callback
* A callback function
*/
cordova.plugins.printer.pick(function (uri) {
alert(uri ? uri : 'Canceled');
});
```
### Print content
Content can be send to a printer through the `printer.print` interface. The method takes a string with HTML content, an URI pointing to another web page or any DOM node.
```javascript
/**
* Sends the content to print service.
* *
* @param {String} content * @param {String} content
* HTML string or DOM node * HTML string or DOM node
* if latter, innerHTML is used to get the content * if latter, innerHTML is used to get the content
* @param {Object} options * @param {Object} options
* Options for the print job * Options for the print job
* @param {Function?} callback * @param {Function} callback
* A callback function * An optional callback function
* @param {Object?} scope * @param {Object} scope
* The scope of the callback (default: window) * An optional scope of the callback
* Defaults to: window
*/ */
cordova.plugins.printer.print(content, options, callback, scope); cordova.plugins.printer.print('<html>..</html>', { duplex: 'long' }, function (res) {
alert(res ? 'Done' : 'Canceled');
});
``` ```
The method accepts a list of attributes. Not all are supported on each platform and by each printer!
| Name | Description | Type | Platform |
| ---- | ----------- |:----:| --------:|
| name | The name of the print job and of the document | String | all |
| duplex | Specifies the duplex mode to use for the print job.<br>Either double-sided on short site (duplex:'short'), double-sided on long site (duplex:'long') or single-sided (duplex:'none').<br>Defaults to: 'none' | String | all |
| landscape| The orientation of the printed content, portrait or landscape.<br>Defaults to: false | Boolean | all |
| graystyle | If your application only prints black text, setting this property to _true_ can result in better performance in many cases.<br>Defaults to: false | Boolean | all |
| printerId | The network URL to the printer. | String | iOS |
| border | Set to _true_ to skip any border. Useful for fullscreen images.<br>Defaults to: true | Boolean | iOS |
| hidePageRange | Set to _true_ to hide the control for the page range.<br>Defaults to: false | Boolean | iOS |
| hideNumberOfCopies | Set to _true_ to hide the control for the number of copies.<br>Defaults to: false | Boolean | iOS |
| hidePaperFormat | Set to _true_ to hide the control for the paper format.<br>Defaults to: false | Boolean | iOS |
| bounds | The Size and position of the print view<br>Defaults to: [40, 30, 0, 0] | Array | iPad |
#### Further informations
- All CSS rules needs to be embedded or accessible via absolute URLs in order to print out HTML encoded content.
- The string can contain HTML content or an URI pointing to another web page.
## Examples ## Examples
__NOTE:__ All CSS rules needs to be embedded or accessible via absolute URLs in order to print out HTML encoded content. __NOTE:__ All CSS rules needs to be embedded or accessible via absolute URLs in order to print out HTML encoded content.
#### 1. Print the whole HTML page Print the whole HTML page:
```javascript ```javascript
// URI for the index.html
var page = location.href; var page = location.href;
cordova.plugins.printer.print(page, 'Document.html', function () { cordova.plugins.printer.print(page, 'Document.html');
alert('printing finished or canceled')
});
``` ```
#### 2. Print the content from a part of the page Print the content from one part of the page:
```javascript ```javascript
// Either a DOM node or a string
var page = document.getElementById('legal-notice'); var page = document.getElementById('legal-notice');
cordova.plugins.printer.print(page, 'Document.html', function () { cordova.plugins.printer.print(page, 'Document.html');
alert('printing finished or canceled')
});
``` ```
#### 3. Print custom specific content Print some custom content:
```javascript ```javascript
// Either a DOM node or a string
var page = '<h1>Hello Document</h1>'; var page = '<h1>Hello Document</h1>';
cordova.plugins.printer.print(page, 'Document.html', function () { cordova.plugins.printer.print(page, 'Document.html');
alert('printing finished or canceled') ```
Print a remote web page:
```javascript
cordova.plugins.printer.print('http://blackberry.de', 'BB10');
```
Send to printer directly:
```javascript
cordova.plugins.printer.pick(function (uri) {
cordova.plugins.printer.print(page, { printerId: uri });
}); });
``` ```
#### 4. Print remote web page
```javascript
cordova.plugins.printer.print('http://blackberry.de', 'BB!!!', function () {
alert('printing finished or canceled')
});
```
#### 5. Adjust the page
```javascript
cordova.plugins.printer.print('123', { name:'Document.html', landscape:true }, function () {
alert('printing finished or canceled')
});
```
#### 6. Custom size and position on iPad
```javascript
// Option one
cordova.plugins.printer.print('123', { bounds:[40, 30, 0, 0] });
// Option two
cordova.plugins.printer.print('123', { bounds:{ left:40, top:30, width:0 height:0 } });
```
### Display printer picker (iOS 8.0+ only)
Displays a system interface allowing the user to select an available printer. The callback function will return the network URL of the selected printer (null if no printer selected). The URL can be passed into the print function (printerId option), allowing a page to be printed without prompting the user. This feature is only available in iOS 8.0 and later.
#### Available Options
| Name | Description | Type | Support |
| ---- | ----------- |:----:| -------:|
| bounds | The Size and position of the printer picker view | Array | iPad |
#### Examples
##### 1. Display the picker
```javascript
cordova.plugins.printer.printerPicker(function (printerId) {
alert(printerId)
});
```
##### 2. Display picker at particular point on the screen and print current page to the selected printer
```javascript
cordova.plugins.printer.printerPicker(function (printerId) {
if(printerId)
{
// URI for the index.html
var page = location.href;
cordova.plugins.printer.print(page, {name: 'Document.html', printerId: printerId }, function () {
alert('Printing finished?')
});
}
else
{
alert('Printer not selected');
}
}, { bounds: { left:100, top:300, width:0, height: 0 } } );
```
## Quirks
### Adding Page Breaks to Printouts
Use the 'page-break-before' property to specify a page break, e.g.
```html
<p>
First page.
</p>
<p style="page-break-before: always">
Second page.
</p>
```
See W3Schools for more more information: http://www.w3schools.com/cssref/pr_print_pagebb.asp
__Note:__ You will need to add an extra top margin to new pages.
## Contributing ## Contributing
@ -315,24 +212,17 @@ __Note:__ You will need to add an extra top margin to new pages.
This software is released under the [Apache 2.0 License][apache2_license]. This software is released under the [Apache 2.0 License][apache2_license].
© 2013-2014 appPlant UG, Inc. All rights reserved Made with :yum: from Leipzig
© 2016 [appPlant GmbH][appplant]
[cordova]: https://cordova.apache.org [cordova]: https://cordova.apache.org
[GCP]: http://www.google.com/cloudprint/learn/index.html
[APF]: http://www.techotopia.com/index.php/Printing_with_the_Android_Printing_Framework
[AirPrint]: http://support.apple.com/kb/ht4356
[master_branch]: #
[google-cloud-print_branch]: https://github.com/katzer/cordova-plugin-printer/tree/google-cloud-print
[network-printer_branch]: https://github.com/katzer/cordova-plugin-printer/tree/network-printer
[ios_guide]: http://developer.apple.com/library/ios/documentation/2ddrawing/conceptual/drawingprintingios/Printing/Printing.html [ios_guide]: http://developer.apple.com/library/ios/documentation/2ddrawing/conceptual/drawingprintingios/Printing/Printing.html
[CLI]: http://cordova.apache.org/docs/en/edge/guide_cli_index.md.html#The%20Command-line%20Interface [android_guide]: https://developer.android.com/training/building-multimedia.html
[PGB]: http://docs.build.phonegap.com/en_US/index.html
[PGB_plugin]: https://build.phonegap.com/plugins/
[changelog]: CHANGELOG.md [changelog]: CHANGELOG.md
[available]: #find-out-if-printing-is-available-on-the-device [check]: #check-printer
[print]: #send-content-to-a-printer [pick]: #pick-a-printer
[examples]: #examples [print]: #print-content
[apache2_license]: http://opensource.org/licenses/Apache-2.0 [apache2_license]: http://opensource.org/licenses/Apache-2.0
[katzer]: katzer@appplant.de
[appplant]: www.appplant.de [appplant]: www.appplant.de