README.md 20 KB

cordova-plugin-media-capture

Build Status

Dieses Plugin ermöglicht den Zugriff auf des Geräts Audio-, Bild- und video-Capture-Funktionen.

Warnung: Erfassung und Verwendung von Bildern, Video oder Audio von Kamera oder das Mikrofon des Geräts wirft wichtige Privatsphäre Fragen. Ihre app-Datenschutzerklärung sollten besprechen, wie die app solche Sensoren verwendet und ob die aufgezeichneten Daten mit irgendwelchen anderen Parteien geteilt werden. Zusätzlich wenn die app-Nutzung der Kamera oder Mikrofon in der Benutzeroberfläche nicht offensichtlich ist, sollten Sie eine just-in-Time Ihnen vorher die app die Kamera oder das Mikrofon zugreift (wenn das Betriebssystem des Geräts bereits tun nicht). Diese Benachrichtigung sollte der gleichen Informationen, die vorstehend, sowie die Zustimmung des Benutzers (z.B. durch Präsentation Entscheidungen für das OK und Nein danke). Beachten Sie, dass einige app-Marktplätze können Ihre app eine Frist von just-in-Time und Erlaubnis des Benutzers vor dem Zugriff auf die Kamera oder das Mikrofon einholen. Weitere Informationen finden Sie in der Datenschutz-Guide.

Dieses Plugin wird global navigator.device.capture-Objekt definiert.

Obwohl im globalen Gültigkeitsbereich, steht es nicht bis nach dem deviceready-Ereignis.

document.addEventListener("deviceready", onDeviceReady, false);
function onDeviceReady() {
    console.log(navigator.device.capture);
}

Installation

cordova plugin add cordova-plugin-media-capture

Unterstützte Plattformen

  • Amazon Fire OS
  • Android
  • BlackBerry 10
  • Browser
  • iOS
  • Windows Phone 7 und 8
  • Windows 8
  • Windows

Objekte

  • Erfassen
  • CaptureAudioOptions
  • CaptureImageOptions
  • CaptureVideoOptions
  • CaptureCallback
  • CaptureErrorCB
  • ConfigurationData
  • MediaFile
  • MediaFileData

Methoden

  • capture.captureAudio
  • capture.captureImage
  • capture.captureVideo
  • MediaFile.getFormatData

Eigenschaften

  • SupportedAudioModes: die Audio-Aufnahme vom Gerät unterstützten Formate. (ConfigurationData[])

  • SupportedImageModes: die Aufnahme Bildgrößen und Formaten, die von dem Gerät unterstützt. (ConfigurationData[])

  • SupportedVideoModes: die Aufnahme Bildschirmauflösungen und Formate, die vom Gerät unterstützt. (ConfigurationData[])

capture.captureAudio

Die audio-Recorder-Anwendung starten und geben Informationen über aufgenommene audio-Clip-Dateien zurück.

navigator.device.capture.captureAudio(
    CaptureCB captureSuccess, CaptureErrorCB captureError,  [CaptureAudioOptions options]
);

Beschreibung

Beginnt einen asynchronen Vorgang, Audioaufnahmen, die audio-Aufnahme-Standardanwendung des Geräts erfassen. Die Operation erlaubt dem Benutzer des Geräts, mehrere Aufnahmen in einer einzigen Sitzung zu erfassen.

Der Capture-Vorgang endet, wenn entweder der Benutzer schließt die Anwendung für die Audioaufnahme, oder die maximale Anzahl der Aufnahmen, die von CaptureAudioOptions.limit angegebene erreicht ist. Wenn kein Grenzwert für den Parameter angegeben ist, wird standardmaessig eins (1) und der Capture-Vorgang beendet, nachdem der Benutzer ein einzelnes audio-Clips aufgezeichnet.

Wenn der Capture-Vorgang abgeschlossen ist, führt die CaptureCallback mit einem Array von MediaFile Objekten beschreibt jede aufgezeichnete audio-Clip-Datei. Wenn der Benutzer den Vorgang beendet wird, bevor ein Audioclip erfasst wird, führt die CaptureErrorCallback mit einem CaptureError-Objekt, mit dem Fehlercode CaptureError.CAPTURE_NO_MEDIA_FILES.

Unterstützte Plattformen

  • Amazon Fire OS
  • Android
  • BlackBerry 10
  • iOS
  • Windows Phone 7 und 8
  • Windows 8
  • Windows

Beispiel

// capture callback
var captureSuccess = function(mediaFiles) {
    var i, path, len;
    for (i = 0, len = mediaFiles.length; i < len; i += 1) {
        path = mediaFiles[i].fullPath;
        // do something interesting with the file
    }
};

// capture error callback
var captureError = function(error) {
    navigator.notification.alert('Error code: ' + error.code, null, 'Capture Error');
};

// start audio capture
navigator.device.capture.captureAudio(captureSuccess, captureError, {limit:2});

iOS Macken

  • iOS muss keine Standard-audio-Recording-Anwendung, so dass eine einfache Benutzeroberfläche bereitgestellt wird.

Windows Phone 7 und 8 Eigenarten

  • Windows Phone 7 muss keine Standard-audio-Recording-Anwendung, so dass eine einfache Benutzeroberfläche bereitgestellt wird.

CaptureAudioOptions

Kapselt Audioaufnahme-Konfigurationsoptionen.

Eigenschaften

  • Limit: die maximale Anzahl von audio-Clips kann Benutzer des Geräts in einem einzigen Capture-Vorgang aufzeichnen. Der Wert muss größer als oder gleich 1 (Standardwert 1).

  • Dauer: die maximale Dauer eines audio-sound-Clips, in Sekunden.

Beispiel

// limit capture operation to 3 media files, no longer than 10 seconds each
var options = { limit: 3, duration: 10 };

navigator.device.capture.captureAudio(captureSuccess, captureError, options);

Amazon Fire OS Macken

  • Die duration Parameter wird nicht unterstützt. Aufnahme Längen kann nicht programmgesteuert begrenzt.

Android Eigenarten

  • Die duration Parameter wird nicht unterstützt. Aufnahme Längen kann nicht programmgesteuert begrenzt.

BlackBerry 10 Macken

  • Die duration Parameter wird nicht unterstützt. Aufnahme Längen kann nicht programmgesteuert begrenzt.
  • Die limit Parameter wird nicht unterstützt, kann also nur eine Aufnahme für jeden Aufruf erstellt werden.

iOS Macken

  • Die limit Parameter wird nicht unterstützt, kann also nur eine Aufnahme für jeden Aufruf erstellt werden.

capture.captureImage

Starten Sie die Kameraanwendung und geben Informationen über aufgenommene Bild-Dateien zurück.

navigator.device.capture.captureImage(
    CaptureCB captureSuccess, CaptureErrorCB captureError, [CaptureImageOptions options]
);

Beschreibung

Beginnt einen asynchronen Vorgang, um Aufnahmen mit Kamera-Anwendung des Geräts. Die Operation erlaubt Benutzern, mehr als ein Bild in einer einzigen Sitzung zu erfassen.

Die Capture Betrieb endet, wenn der Benutzer schließt die Kameraanwendung oder die maximale Anzahl der Aufnahmen, die durch CaptureAudioOptions.limit angegeben ist erreicht. Wenn kein Grenzwert angegeben ist, wird eins (1 standardmaessig) und der Capture-Vorgang beendet nach fängt der Benutzer ein einzelnes Bild.

Wenn der Capture-Vorgang abgeschlossen ist, ruft es den CaptureCB-Rückruf mit einem Array von MediaFile Objekten beschreibt jede aufgenommene Bild-Datei. Wenn der Benutzer den Vorgang vor dem Aufzeichnen eines Abbilds beendet wird, führt der CaptureErrorCB-Rückruf mit einem CaptureError-Objekt mit einem CaptureError.CAPTURE_NO_MEDIA_FILES-Fehlercode.

Unterstützte Plattformen

  • Amazon Fire OS
  • Android
  • BlackBerry 10
  • Browser
  • iOS
  • Windows Phone 7 und 8
  • Windows 8
  • Windows

Windows Phone 7 Macken

Die native Kameraanwendung aufrufen, während Ihr Gerät via Zune angeschlossen ist, funktioniert nicht, und die Fehler-Callback führt.

Browser-Eigenheiten

Arbeitet in Chrome, Firefox und Opera nur (da IE und Safari nicht unterstützt navigator.getUserMedia-API)

Anzeigen von Bildern mit erfasst nur Datei-URL in Chrome/Opera verfügbar. Firefox speichert die aufgenommenen Bilder in IndexedDB Speicher (siehe Datei-Plugin-Dokumentation), und aus diesem Grund ist die einzige Möglichkeit, aufgenommene Bild zeigen es und zeigen mit ihrer DataURL lesen.

Beispiel

// capture callback
var captureSuccess = function(mediaFiles) {
    var i, path, len;
    for (i = 0, len = mediaFiles.length; i < len; i += 1) {
        path = mediaFiles[i].fullPath;
        // do something interesting with the file
    }
};

// capture error callback
var captureError = function(error) {
    navigator.notification.alert('Error code: ' + error.code, null, 'Capture Error');
};

// start image capture
navigator.device.capture.captureImage(captureSuccess, captureError, {limit:2});

CaptureImageOptions

Image Capture-Konfigurationsoptionen kapselt.

Eigenschaften

  • Limit: die maximale Anzahl der Bilder, die der Benutzer zu, die in einem einzigen Capture-Vorgang erfassen. Der Wert muss größer als oder gleich 1 (Standardwert 1).

Beispiel

// limit capture operation to 3 images
var options = { limit: 3 };

navigator.device.capture.captureImage(captureSuccess, captureError, options);

iOS Macken

  • Der Limit -Parameter wird nicht unterstützt, und nur ein Bild pro Aufruf stammt.

capture.captureVideo

Die Videorecorder-Anwendung starten und geben Informationen zu aufgezeichneten video-Clip-Dateien zurück.

navigator.device.capture.captureVideo(
    CaptureCB captureSuccess, CaptureErrorCB captureError, [CaptureVideoOptions options]
);

Beschreibung

Beginnt einen asynchronen Vorgang um Videoaufnahmen mit Videoaufzeichnung-Anwendung des Geräts zu erfassen. Die Operation ermöglicht dem Benutzer, mehrere Aufnahmen in einer einzigen Sitzung zu erfassen.

Der Capture-Vorgang endet, wenn entweder der Benutzer schließt die Anwendung für die Audioaufnahme, oder die maximale Anzahl der Aufnahmen, die von CaptureAudioOptions.limit angegebene erreicht ist. Wenn kein Grenzwert für den Parameter angegeben ist, wird standardmaessig eins (1) und der Capture-Vorgang beendet, nachdem der Benutzer einen einzelnen video Clip aufgezeichnet.

Der Capture-Vorgang abgeschlossen ist, führt er der CaptureCB-Rückruf mit einem Array von MediaFile Objekten beschreibt jede aufgezeichnete video-Clip-Datei. Wenn der Benutzer den Vorgang vor dem Erfassen eines Videoclips beendet wird, führt der CaptureErrorCB-Rückruf mit einem CaptureError-Objekt mit einem CaptureError.CAPTURE_NO_MEDIA_FILES-Fehlercode.

Unterstützte Plattformen

  • Amazon Fire OS
  • Android
  • BlackBerry 10
  • iOS
  • Windows Phone 7 und 8
  • Windows 8
  • Windows

Beispiel

// capture callback
var captureSuccess = function(mediaFiles) {
    var i, path, len;
    for (i = 0, len = mediaFiles.length; i < len; i += 1) {
        path = mediaFiles[i].fullPath;
        // do something interesting with the file
    }
};

// capture error callback
var captureError = function(error) {
    navigator.notification.alert('Error code: ' + error.code, null, 'Capture Error');
};

// start video capture
navigator.device.capture.captureVideo(captureSuccess, captureError, {limit:2});

BlackBerry 10 Macken

  • Cordova für BlackBerry 10 versucht, Video-Recorder Starten der Anwendung, bereitgestellt durch RIM, Videoaufnahmen zu erfassen. Die app erhält eine CaptureError.CAPTURE_NOT_SUPPORTED Fehlercode, wenn die Anwendung nicht auf dem Gerät installiert ist.

CaptureVideoOptions

Video-Capture-Konfigurationsoptionen kapselt.

Eigenschaften

  • Limit: die maximale Anzahl von video-Clips des Geräts Benutzer kann in einem einzigen Capture-Vorgang erfassen. Der Wert muss größer als oder gleich 1 (Standardwert 1).

  • Dauer: die maximale Dauer eines Videoclips in Sekunden.

Beispiel

// limit capture operation to 3 video clips
var options = { limit: 3 };

navigator.device.capture.captureVideo(captureSuccess, captureError, options);

BlackBerry 10 Macken

  • Der Duration -Parameter wird nicht unterstützt, so dass die Länge der Aufnahmen programmgesteuert nur beschränkt sein kann.

iOS Macken

  • Der Limit -Parameter wird nicht unterstützt. Pro Aufruf wird nur ein Video aufgezeichnet.

CaptureCB

Auf eine erfolgreiche Media-Erfassungsvorgangs aufgerufen.

function captureSuccess( MediaFile[] mediaFiles ) { ... };

Beschreibung

Diese Funktion wird ausgeführt, nachdem ein erfolgreiche Capture-Vorgang abgeschlossen ist. An diesem Punkt kann eine Mediendatei erfasst wurden und entweder der Benutzer die Medien-Capture-Anwendung beendet hat oder die Capture-erreicht.

Jedes MediaFile-Objekt beschreibt eine aufgenommenen Medien-Datei.

Beispiel

// capture callback
function captureSuccess(mediaFiles) {
    var i, path, len;
    for (i = 0, len = mediaFiles.length; i < len; i += 1) {
        path = mediaFiles[i].fullPath;
        // do something interesting with the file
    }
};

CaptureError

Kapselt den Fehlercode, der infolge eines fehlerhaften Medien-Erfassungsvorgangs.

Eigenschaften

  • Code: einer der vordefinierten Fehlercodes aufgeführt.

Konstanten

  • CaptureError.CAPTURE_INTERNAL_ERR: Die Kamera oder das Mikrofon konnte Bild oder Ton zu erfassen.

  • CaptureError.CAPTURE_APPLICATION_BUSY: Eine weitere Aufnahme-Anforderung verbüßt die Kamera oder Audio-Capture-Anwendung.

  • CaptureError.CAPTURE_INVALID_ARGUMENT: Ungültige Verwendung der API (z. B. den Wert des limit ist kleiner als 1).

  • CaptureError.CAPTURE_NO_MEDIA_FILES: Der Benutzer wird die Kamera oder Audio-Capture-Anwendung vor Aufnahme alles beendet.

  • CaptureError.CAPTURE_NOT_SUPPORTED: Der angeforderte Capture-Vorgang wird nicht unterstützt.

CaptureErrorCB

Wird aufgerufen, wenn ein Fehler, während eines Medien auftritt.

function captureError( CaptureError error ) { ... };

Beschreibung

Diese Funktion wird ausgeführt, wenn ein Fehler auftritt, wenn Sie versuchen, starten Sie ein Medium capture Betrieb. Fehlerszenarien enthalten, wenn die Sicherungsanwendung beschäftigt, ein Capture-Vorgang ist bereits im Gange, oder der Benutzer den Vorgang abbricht, bevor alle Mediendateien erfasst werden.

Diese Funktion führt mit einem CaptureError-Objekt enthält einen entsprechenden Fehler-code.

Beispiel

// capture error callback
var captureError = function(error) {
    navigator.notification.alert('Error code: ' + error.code, null, 'Capture Error');
};

ConfigurationData

Kapselt eine Reihe von Medien-Aufnahme-Parameter, die ein Gerät unterstützt.

Beschreibung

Beschreibt Medien-Aufnahmemodi, die vom Gerät unterstützt. Die Konfigurationsdaten enthält den MIME-Typ und Capture Dimensionen für die Aufnahme von Video- oder Bilddateien.

Die MIME-Typen sollten RFC2046 einhalten. Beispiele:

  • video/3gpp
  • video/quicktime
  • image/jpeg
  • audio/amr
  • audio/wav

Eigenschaften

  • Typ: die ASCII-codierte Zeichenfolge aus Kleinbuchstaben, den Medientyp darstellt. (DOM-String und enthält)

  • Höhe: die Höhe des Bildes oder Videos in Pixel. Der Wert ist NULL für sound-Clips. (Anzahl)

  • Breite: die Breite des Bildes oder Videos in Pixel. Der Wert ist NULL für sound-Clips. (Anzahl)

Beispiel

// retrieve supported image modes
var imageModes = navigator.device.capture.supportedImageModes;

// Select mode that has the highest horizontal resolution
var width = 0;
var selectedmode;
for each (var mode in imageModes) {
    if (mode.width > width) {
        width = mode.width;
        selectedmode = mode;
    }
}

Von jeder Plattform unterstützt nicht. Alle Konfigurations-Daten-Arrays sind leer.

MediaFile.getFormatData

Ruft formatieren Informationen über die Medien-Capture-Datei.

mediaFile.getFormatData(
    MediaFileDataSuccessCB successCallback,
    [MediaFileDataErrorCB errorCallback]
);

Beschreibung

Diese Funktion versucht asynchron, die Formatierungsinformationen für die Mediendatei abzurufen. Wenn erfolgreich, wird den MediaFileDataSuccessCB-Rückruf mit einem MediaFileData-Objekt. Wenn dieser Versuch fehlschlägt, ruft diese Funktion den MediaFileDataErrorCB-Rückruf.

Unterstützte Plattformen

  • Amazon Fire OS
  • Android
  • BlackBerry 10
  • iOS
  • Windows Phone 7 und 8
  • Windows 8
  • Windows

Amazon Fire OS Macken

Die API zum Zugriff Medien Dateiformat-Information ist begrenzt, so dass nicht alle MediaFileData Eigenschaften werden unterstützt.

BlackBerry 10 Macken

Bietet keine API Informationen zum Media-Dateien, so dass alle MediaFileData-Objekte mit Standardwerten zurück.

Android Eigenarten

Die API zum Zugriff Medien Dateiformat-Information ist begrenzt, so dass nicht alle MediaFileData Eigenschaften werden unterstützt.

iOS Macken

Die API zum Zugriff Medien Dateiformat-Information ist begrenzt, so dass nicht alle MediaFileData Eigenschaften werden unterstützt.

MediaFile

Kapselt Eigenschaften einer Mediendatei erfassen.

Eigenschaften

  • Name: der Name der Datei, ohne Pfadinformationen. (DOM-String und enthält)

  • FullPath: der vollständige Pfad der Datei, einschließlich des Namens. (DOM-String und enthält)

  • Typ: Mime-Typ der Datei (DOM-String und enthält)

  • LastModifiedDate: das Datum und die Uhrzeit wann die Datei zuletzt geändert wurde. (Datum)

  • Größe: die Größe der Datei in Byte. (Anzahl)

Methoden

  • MediaFile.getFormatData: Ruft die Formatierungsinformationen der Mediendatei.

MediaFileData

Kapselt Formatinformationen zu einer Mediendatei.

Eigenschaften

  • Codecs: das tatsächliche Format der Audio- und video-Inhalte. (DOM-String und enthält)

  • Bitrate: die durchschnittliche Bitrate des Inhalts. Der Wert ist NULL für Bilder. (Anzahl)

  • Höhe: die Höhe des Bildes oder Videos in Pixel. Der Wert ist NULL für audio-Clips. (Anzahl)

  • Breite: die Breite des Bildes oder Videos in Pixel. Der Wert ist NULL für audio-Clips. (Anzahl)

  • Dauer: die Länge des Video- oder Clips in Sekunden. Der Wert ist NULL für Bilder. (Anzahl)

BlackBerry 10 Macken

Keine API bietet Formatierungsinformationen für Mediendateien, so dass das MediaFileData-Objekt durch MediaFile.getFormatData Features die folgenden Standardwerte zurückgegeben:

  • Codecs: nicht unterstützt, und gibtnull.

  • Bitrate: nicht unterstützt, und gibt den Wert NULL.

  • Höhe: nicht unterstützt, und gibt den Wert NULL.

  • Breite: nicht unterstützt, und gibt den Wert NULL.

  • Dauer: nicht unterstützt, und gibt den Wert NULL.

Amazon Fire OS Macken

Unterstützt die folgenden MediaFileData Eigenschaften:

  • Codecs: nicht unterstützt, und gibtnull.

  • Bitrate: nicht unterstützt, und gibt den Wert NULL.

  • Höhe: unterstützt: nur Bild und Video-Dateien.

  • Breite: unterstützt: nur Bild und Video-Dateien.

  • Dauer: unterstützt: Audio- und video-Dateien nur

Android Eigenarten

Unterstützt die folgenden MediaFileData Eigenschaften:

  • Codecs: nicht unterstützt, und gibtnull.

  • Bitrate: nicht unterstützt, und gibt den Wert NULL.

  • Höhe: unterstützt: nur Bild und Video-Dateien.

  • Breite: unterstützt: nur Bild und Video-Dateien.

  • Dauer: unterstützt: Audio- und video-Dateien nur.

iOS Macken

Unterstützt die folgenden MediaFileData Eigenschaften:

  • Codecs: nicht unterstützt, und gibtnull.

  • Bitrate: iOS4 Geräten für nur Audio unterstützt. Gibt 0 (null) für Bilder und Videos.

  • Höhe: unterstützt: nur Bild und Video-Dateien.

  • Breite: unterstützt: nur Bild und Video-Dateien.

  • Dauer: unterstützt: Audio- und video-Dateien nur.