Cordova - Kamera
Bu eklenti, fotoğraf çekmek veya resim galerisindeki dosyaları kullanmak için kullanılır.
Adım 1 - Kamera Eklentisini Kurun
Aşağıdaki kodu, command prompt Bu eklentiyi yüklemek için pencere.
C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugincamera
Adım 2 - Düğme ve Resim Ekleme
Şimdi, kamerayı çağırmak için bir düğme oluşturacağız ve imggörüntünün çekildikten sonra görüntüleneceği yer. Bu, şuraya eklenecekindex.html içinde div class = "app" öğesi.
<button id = "cameraTakePicture">TAKE PICTURE</button>
<img id = "myImage"></img>
3. Adım - Etkinlik İşleyici Ekleme
Olay dinleyicisi, onDeviceReady Kullanmaya başlamadan önce Cordova'nın yüklendiğinden emin olmak için bir işlev.
document.getElementById("cameraTakePicture").addEventListener
("click", cameraTakePicture);
Adım 4 - İşlev Ekleme (fotoğraf çekme)
Biz yaratacağız cameraTakePictureolay dinleyicimize geri çağrı olarak iletilen işlev. Düğmeye dokunulduğunda ateşlenecektir. Bu fonksiyonun içinde,navigator.cameraeklenti API'si tarafından sağlanan genel nesne. Fotoğraf çekimi başarılı olursa, verileronSuccessgeri arama işlevi değilse, hata mesajı içeren uyarı gösterilecektir. Bu kodu sayfanın altına yerleştireceğizindex.js.
function cameraTakePicture() {
navigator.camera.getPicture(onSuccess, onFail, {
quality: 50,
destinationType: Camera.DestinationType.DATA_URL
});
function onSuccess(imageData) {
var image = document.getElementById('myImage');
image.src = "data:image/jpeg;base64," + imageData;
}
function onFail(message) {
alert('Failed because: ' + message);
}
}
Uygulamayı çalıştırdığımızda ve düğmeye bastığımızda, yerel kamera tetiklenecek.
Fotoğraf çekip kaydettiğimizde ekranda görüntülenecektir.
Aynı prosedür yerel dosya sisteminden görüntü almak için kullanılabilir. Tek fark, son adımda oluşturulan işlevdir. GörebilirsinizsourceType isteğe bağlı parametre eklendi.
1. Adım B
C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugincamera
2. Adım B
<button id = "cameraGetPicture">GET PICTURE</button>
3. Adım B
document.getElementById("cameraGetPicture").addEventListener("click", cameraGetPicture);
4. Adım B
function cameraGetPicture() {
navigator.camera.getPicture(onSuccess, onFail, { quality: 50,
destinationType: Camera.DestinationType.DATA_URL,
sourceType: Camera.PictureSourceType.PHOTOLIBRARY
});
function onSuccess(imageURL) {
var image = document.getElementById('myImage');
image.src = imageURL;
}
function onFail(message) {
alert('Failed because: ' + message);
}
}
İkinci düğmeye bastığımızda kamera yerine dosya sistemi açılacak, böylece görüntülenecek görüntüyü seçebiliriz.
Bu eklenti, özelleştirme için birçok isteğe bağlı parametre sunar.
S.No | Parametre ve Detaylar |
---|---|
1 | quality 0-100 aralığında görüntünün kalitesi. Varsayılan 50'dir. |
2 | destinationType DATA_URL veya 0 Base64 kodlu dizeyi döndürür. FILE_URI veya 1 Görüntü dosyası URI'sini döndürür. NATIVE_URI veya 2 Görüntü yerel URI'sini döndürür. |
3 | sourceType PHOTOLIBRARY veya 0 Fotoğraf kitaplığını açar. CAMERA veya 1 Yerel kamerayı açar. SAVEDPHOTOALBUM veya 2 Kaydedilmiş fotoğraf albümünü açar. |
4 | allowEdit Görüntü düzenlemeye izin verir. |
5 | encodingType JPEG veya 0 JPEG olarak kodlanmış görüntüyü döndürür. PNG veya 1 PNG kodlu resmi döndürür. |
6 | targetWidth Piksel cinsinden görüntü ölçekleme genişliği. |
7 | targetHeight Piksel cinsinden görüntü ölçekleme yüksekliği. |
8 | mediaType PICTURE veya 0 Yalnızca resim seçimine izin verir. VIDEO veya 1 Yalnızca video seçimine izin verir. ALLMEDIA veya 2 Tüm ortam türü seçimine izin verir. |
9 | correctOrientation Görüntünün yönünü düzeltmek için kullanılır. |
10 | saveToPhotoAlbum Görüntüyü fotoğraf albümüne kaydetmek için kullanılır. |
11 | popoverOptions IOS'ta açılır pencere konumunu ayarlamak için kullanılır. |
12 | cameraDirection FRONT veya 0 Ön kamera. BACK veya 1 Arka kamera. ALLMEDIA |