Caméra Ionic - Cordova
Le plugin de la caméra Cordova utilise le native camera pour prendre des photos ou obtenir des images de la galerie d'images.
Utilisation de la caméra
Ouvrez le dossier racine de votre projet dans l'invite de commande, puis téléchargez et installez le plug-in de caméra Cordova avec la commande suivante.
C:\Users\Username\Desktop\MyApp> cordova plugin add org.apache.cordova.camera
Maintenant, nous allons créer un service pour utiliser un plugin de caméra. Nous utiliserons leAngularJS factory et promettre un objet $q qui doit être injecté à l'usine.
Code services.js
.factory('Camera', function($q) {
return {
getPicture: function(options) {
var q = $q.defer();
navigator.camera.getPicture(function(result) {
q.resolve(result);
}, function(err) {
q.reject(err);
}, options);
return q.promise;
}
}
});
Pour utiliser ce service dans l'application, nous devons l'injecter dans un contrôleur en tant que dépendance. L'API de la caméra Cordova fournitgetPicture méthode, qui est utilisée pour prendre des photos à l'aide d'un appareil photo natif.
Les paramètres natifs de la caméra peuvent être en outre personnalisés en passant le options paramètre au takePicturefonction. Copiez l'exemple de code mentionné ci-dessus sur votre contrôleur pour déclencher ce comportement. Il ouvrira l'application de l'appareil photo et retournera une fonction de rappel de succès avec les données d'image ou une fonction de rappel d'erreur avec un message d'erreur. Nous aurons également besoin de deux boutons qui appelleront les fonctions que nous sommes sur le point de créer et nous devons afficher l'image à l'écran.
Code HTML
<button class = "button" ng-click = "takePicture()">Take Picture</button>
<button class = "button" ng-click = "getPicture()">Open Gallery</button>
<img ng-src = "{{user.picture}}">
Code du contrôleur
.controller('MyCtrl', function($scope, Camera) {
$scope.takePicture = function (options) {
var options = {
quality : 75,
targetWidth: 200,
targetHeight: 200,
sourceType: 1
};
Camera.getPicture(options).then(function(imageData) {
$scope.picture = imageData;;
}, function(err) {
console.log(err);
});
};
})
La sortie ressemblera à celle de la capture d'écran suivante.
Si vous souhaitez utiliser des images de votre galerie, la seule chose que vous devez modifier est le sourceTypeméthode à partir de votre paramètre d'options. Cette modification ouvrira une boîte de dialogue au lieu de la caméra et vous permettra de choisir l'image que vous souhaitez sur l'appareil.
Vous pouvez voir le code suivant, où le sourceType l'option est remplacée par 0. Maintenant, lorsque vous appuyez sur le deuxième bouton, il ouvrira le menu fichier à partir de l'appareil.
Code du contrôleur
.controller('MyCtrl', function($scope, Camera) {
$scope.getPicture = function (options) {
var options = {
quality : 75,
targetWidth: 200,
targetHeight: 200,
sourceType: 0
};
Camera.getPicture(options).then(function(imageData) {
$scope.picture = imageData;;
}, function(err) {
console.log(err);
});
};
})
La sortie ressemblera à celle de la capture d'écran suivante.
Lorsque vous enregistrez l'image que vous avez prise, elle apparaîtra à l'écran. Vous pouvez le coiffer comme vous le souhaitez.
Plusieurs autres options peuvent également être utilisées, dont certaines sont données dans le tableau suivant.
Paramètre | Type | Détails |
---|---|---|
qualité | Nombre | La qualité de l'image, comprise entre 0 et 100 |
destinationType | Nombre | Format de l'image. |
Type de Source | Nombre | Utilisé pour régler la source de l'image. |
allowEdit | booléen | Utilisé pour permettre l'édition de l'image. |
encodingType | Nombre | La valeur 0 définira JPEG et la valeur 1 définira PNG. |
targetWidth | Nombre | Utilisé pour mettre à l'échelle la largeur de l'image. |
targetHeight | Nombre | Utilisé pour mettre à l'échelle la hauteur de l'image. |
type de support | chaîne | Utilisé pour définir le type de support. |
cameraDirection | Nombre | La valeur 0 définira la caméra arrière et la valeur 1 définira la caméra avant. |
popoverOptions | chaîne | Options IOS uniquement qui spécifient l'emplacement de popover sur l'iPad. |
saveToPhotoAlbum | booléen | Utilisé pour enregistrer l'image dans l'album photo. |
correctOrientation | booléen | Utilisé pour corriger l'orientation des images capturées. |