आयनिक - कॉर्डोवा कैमरा

कॉर्डोवा कैमरा प्लगइन का उपयोग करता है native camera चित्र लेने या छवि गैलरी से चित्र प्राप्त करने के लिए।

कैमरा का उपयोग करना

कमांड प्रॉम्प्ट में अपना प्रोजेक्ट रूट फ़ोल्डर खोलें, फिर निम्न कमांड के साथ कॉर्डोवा कैमरा प्लगइन डाउनलोड और इंस्टॉल करें।

C:\Users\Username\Desktop\MyApp> cordova plugin add org.apache.cordova.camera

अब, हम एक कैमरा प्लगइन का उपयोग करने के लिए एक सेवा बनाएंगे। हम उपयोग करेंगेAngularJS factory और वादा वस्तु $q कि कारखाने के लिए इंजेक्शन की जरूरत है।

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;
      }
   }
});

ऐप में इस सेवा का उपयोग करने के लिए, हमें एक नियंत्रक पर निर्भरता के रूप में इसे इंजेक्ट करने की आवश्यकता है। कॉर्डोवा कैमरा एपीआई प्रदान करता हैgetPicture विधि, जो एक देशी कैमरे का उपयोग करके फ़ोटो लेने के लिए उपयोग की जाती है।

देशी कैमरा सेटिंग्स को इसके द्वारा पारित किया जा सकता है options के लिए पैरामीटर takePictureसमारोह। इस व्यवहार को ट्रिगर करने के लिए अपने नियंत्रक को उपर्युक्त कोड नमूना कॉपी करें। यह कैमरा एप्लिकेशन को खोलेगा और एक त्रुटि संदेश के साथ छवि डेटा या त्रुटि कॉलबैक फ़ंक्शन के साथ एक सफलता कॉलबैक फ़ंक्शन लौटाएगा। हमें दो बटनों की भी आवश्यकता होगी जो उन कार्यों को कॉल करेंगे जिन्हें हम बनाने जा रहे हैं और हमें स्क्रीन पर छवि दिखाने की आवश्यकता है।

HTML कोड

<button class = "button" ng-click = "takePicture()">Take Picture</button>
<button class = "button" ng-click = "getPicture()">Open Gallery</button>
<img ng-src = "{{user.picture}}">

नियंत्रक कोड

.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);
      });
   };
})

आउटपुट निम्न स्क्रीनशॉट में दिखाया गया है।

यदि आप अपनी गैलरी से छवियों का उपयोग करना चाहते हैं, तो आपको केवल एक चीज को बदलने की आवश्यकता है sourceTypeआपके विकल्प पैरामीटर से विधि। यह परिवर्तन कैमरे के बजाय एक संवाद पॉपअप खोलेगा और आपको डिवाइस से अपनी इच्छित छवि चुनने की अनुमति देगा।

आप निम्न कोड देख सकते हैं, जहां sourceType विकल्प को बदल दिया गया है 0। अब, जब आप दूसरे बटन पर टैप करेंगे, तो यह डिवाइस से फाइल मेन्यू को खोलेगा।

नियंत्रक कोड

.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);
      });
   };  
})

आउटपुट निम्न स्क्रीनशॉट में दिखाया गया है।

जब आप ली गई छवि को सहेजते हैं, तो यह स्क्रीन पर दिखाई देगा। आप इसे अपनी इच्छानुसार स्टाइल कर सकते हैं।

कई अन्य विकल्पों का भी उपयोग किया जा सकता है, जिनमें से कुछ निम्नलिखित तालिका में दिए गए हैं।

पैरामीटर प्रकार विवरण
गुणवत्ता संख्या छवि की गुणवत्ता, रेंज 0-100
destinationType संख्या छवि का प्रारूप।
स्रोत प्रकार संख्या चित्र के स्रोत को सेट करने के लिए उपयोग किया जाता है।
allowEdit बूलियन छवि के संपादन की अनुमति देने के लिए उपयोग किया जाता है।
encodingType संख्या मान 0 JPEG सेट करेगा, और मान 1 PNG सेट करेगा।
targetWidth संख्या छवि चौड़ाई स्केल करने के लिए उपयोग किया जाता है।
targetHeight संख्या छवि ऊंचाई स्केलिंग के लिए उपयोग किया जाता है।
मीडिया का स्वरूप तार मीडिया प्रकार सेट करने के लिए उपयोग किया जाता है।
cameraDirection संख्या मान 0 बैक कैमरा सेट करेगा, और मान 1 फ्रंट कैमरा सेट करेगा।
popoverOptions तार IOS- केवल विकल्प जो iPad में पॉपओवर स्थान निर्दिष्ट करते हैं।
saveToPhotoAlbum बूलियन छवि को फोटो एलबम में सहेजने के लिए उपयोग किया जाता है।
correctOrientation बूलियन कैप्चर की गई इमेज के ओरिएंटेशन को सही करने के लिए उपयोग किया जाता है।