mirror of
https://github.com/danielsogl/awesome-cordova-plugins.git
synced 2025-02-14 04:05:23 +08:00
86 lines
2.2 KiB
TypeScript
86 lines
2.2 KiB
TypeScript
import { Injectable } from '@angular/core';
|
|
import { Plugin, IonicNativePlugin } from '@ionic-native/core';
|
|
|
|
|
|
declare var navigator: any;
|
|
/**
|
|
* @name Screenshot
|
|
* @description Captures a screen shot
|
|
* @usage
|
|
* ```typescript
|
|
* import { Screenshot } from '@ionic-native/screenshot';
|
|
*
|
|
* constructor(private screenshot: Screenshot) { }
|
|
*
|
|
* ...
|
|
*
|
|
* // Take a screenshot and save to file
|
|
* this.screenshot.save('jpg', 80, 'myscreenshot.jpg').then(onSuccess, onError);
|
|
*
|
|
* // Take a screenshot and get temporary file URI
|
|
* this.screenshot.URI(80).then(onSuccess, onError);
|
|
* ```
|
|
*/
|
|
@Plugin({
|
|
pluginName: 'Screenshot',
|
|
plugin: 'https://github.com/gitawego/cordova-screenshot.git',
|
|
pluginRef: 'navigator.screenshot',
|
|
repo: 'https://github.com/gitawego/cordova-screenshot.git'
|
|
})
|
|
@Injectable()
|
|
export class Screenshot extends IonicNativePlugin {
|
|
|
|
/**
|
|
* Takes screenshot and saves the image
|
|
*
|
|
* @param {string} format. Format can take the value of either 'jpg' or 'png'
|
|
* On ios, only 'jpg' format is supported
|
|
* @param {number} quality. Determines the quality of the screenshot.
|
|
* Default quality is set to 100.
|
|
* @param {string} filename. Name of the file as stored on the storage
|
|
* @returns {Promise<any>}
|
|
*/
|
|
save(format?: string, quality?: number, filename?: string): Promise<any> {
|
|
return new Promise<any>(
|
|
(resolve, reject) => {
|
|
navigator.screenshot.save(
|
|
(error, result) => {
|
|
if (error) {
|
|
reject(error);
|
|
} else {
|
|
resolve(result);
|
|
}
|
|
},
|
|
format,
|
|
quality,
|
|
filename
|
|
);
|
|
}
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Takes screenshot and returns the image as an URI
|
|
*
|
|
* @param {number} quality. Determines the quality of the screenshot.
|
|
* Default quality is set to 100.
|
|
* @returns {Promise<any>}
|
|
*/
|
|
URI(quality?: number): Promise<any> {
|
|
return new Promise<any>(
|
|
(resolve, reject) => {
|
|
navigator.screenshot.URI(
|
|
(error, result) => {
|
|
if (error) {
|
|
reject(error);
|
|
} else {
|
|
resolve(result);
|
|
}
|
|
},
|
|
quality
|
|
);
|
|
}
|
|
);
|
|
}
|
|
}
|