Cordova - Panduan Cepat

Cordova adalah platform untuk membangun aplikasi seluler hybrid menggunakan HTML, CSS, dan JavaScript.

Dokumentasi resmi memberi kita definisi Cordova -

"Apache Cordova adalah kerangka kerja pengembangan seluler sumber terbuka. Ini memungkinkan Anda menggunakan teknologi web standar seperti HTML5, CSS3, dan JavaScript untuk pengembangan lintas platform, menghindari setiap bahasa pengembangan asli platform seluler. Aplikasi dijalankan dalam pembungkus yang ditargetkan ke setiap platform, dan mengandalkan binding API yang sesuai standar untuk mengakses setiap sensor perangkat, data, dan status jaringan. "

Fitur Cordova

Mari kita sekarang memahami fitur Cordova secara singkat.

Antarmuka Baris Perintah (Cordova CLI)

Alat ini dapat digunakan untuk memulai proyek, membangun proses untuk berbagai platform, memasang plugin, dan banyak hal berguna lainnya yang mempermudah proses pengembangan. Anda akan mempelajari cara menggunakan Antarmuka Baris Perintah di bab-bab berikutnya.

Komponen Inti Cordova

Cordova menawarkan seperangkat komponen inti yang dibutuhkan setiap aplikasi seluler. Komponen ini akan digunakan untuk membuat basis aplikasi sehingga kita dapat menghabiskan lebih banyak waktu untuk mengimplementasikan logika kita sendiri.

Plugin Cordova

Cordova menawarkan API yang akan digunakan untuk mengimplementasikan fungsi seluler asli ke aplikasi JavaScript kami.

Lisensi

Cordova dilisensikan di bawah Lisensi Apache, Versi 2.0. Logo Apache dan bulu Apache adalah merek dagang dari The Apache Software Foundation.

Keunggulan Cordova

Sekarang kita akan membahas keunggulan Cordova.

  • Cordova menawarkan satu platform untuk membangun aplikasi seluler hibrid sehingga kami dapat mengembangkan satu aplikasi yang akan digunakan pada platform seluler yang berbeda - iOS, Android, Windows Phone, Amazon-fireos, blackberry, Firefox OS, Ubuntu, dan tizien.

  • Lebih cepat mengembangkan aplikasi hybrid daripada aplikasi asli sehingga Cordova dapat menghemat waktu pengembangan.

  • Karena kami menggunakan JavaScript saat bekerja dengan Cordova, kami tidak perlu mempelajari bahasa pemrograman khusus platform.

  • Ada banyak pengaya komunitas yang dapat digunakan dengan Cordova, ini memiliki beberapa perpustakaan dan kerangka kerja, yang dioptimalkan untuk bekerja dengannya.

Batasan Cordova

Berikut adalah batasan Cordova.

  • Aplikasi hibrid lebih lambat daripada yang asli sehingga tidak optimal menggunakan Cordova untuk aplikasi besar yang membutuhkan banyak data dan fungsionalitas.

  • Kompatibilitas lintas browser dapat menimbulkan banyak masalah. Sebagian besar waktu kami membuat aplikasi untuk platform yang berbeda sehingga pengujian dan pengoptimalan dapat memakan waktu karena kami perlu mencakup sejumlah besar perangkat dan sistem operasi.

  • Beberapa plugin memiliki masalah kompatibilitas dengan perangkat dan platform yang berbeda. Ada juga beberapa API asli yang belum didukung oleh Cordova.

Dalam bab ini, kita akan memahami Pengaturan Lingkungan Cordova. Untuk memulai pengaturan, pertama-tama kita perlu menginstal beberapa komponen. Komponennya tercantum dalam tabel berikut.

S.No Software & Deskripsi
1

NodeJS and NPM

NodeJS adalah platform yang dibutuhkan untuk pengembangan Cordova. Lihat Pengaturan Lingkungan NodeJS kami untuk lebih jelasnya.

2

Android SDK

Untuk platform Android, Anda harus menginstal Android SDK di komputer Anda. Lihat Penyiapan Lingkungan Android untuk detail selengkapnya.

3

XCode

Untuk platform iOS, Anda harus menginstal xCode di komputer Anda. Lihat Pengaturan Lingkungan iOS untuk lebih jelasnya

Memasang Cordova

Sebelum kita mulai, perlu Anda ketahui bahwa kami akan menggunakan Windows command prompt dalam tutorial kami.

Langkah 1 - Menginstal git

Bahkan jika Anda tidak menggunakan git, itu harus dipasang karena Cordova menggunakannya untuk beberapa proses latar belakang. Anda dapat mengunduh git di sini . Setelah Anda menginstal git, buka variabel lingkungan Anda.

  • Klik kanan pada Komputer
  • Properties
  • Pengaturan Sistem Lanjutan
  • Variabel Lingkungan
  • Variabel Sistem
  • Edit

Salin yang berikut ini di akhir variable value field. Ini adalah jalur default dari instalasi git. Jika Anda menginstalnya di jalur yang berbeda, Anda harus menggunakannya sebagai pengganti kode contoh kami di bawah ini.

;C:\Program Files (x86)\Git\bin;C:\Program Files (x86)\Git\cmd

Sekarang Anda bisa mengetik git di prompt perintah Anda untuk menguji apakah penginstalan berhasil.

Langkah 2 - Memasang Cordova

Langkah ini akan mengunduh dan menginstal modul Cordova secara global. Buka command prompt dan jalankan perintah berikut -

C:\Users\username>npm install -g cordova

Anda dapat memeriksa versi yang diinstal dengan menjalankan -

C:\Users\username>cordova -v

Ini adalah semua yang Anda butuhkan untuk mulai mengembangkan aplikasi Cordova di sistem operasi Windows. Dalam tutorial kami berikutnya, kami akan menunjukkan cara membuat aplikasi pertama.

Kami telah memahami cara memasang Cordova dan mengatur lingkungannya. Setelah semuanya siap, kita dapat membuat aplikasi Cordova hybrid pertama kita.

Langkah 1 - Membuat Aplikasi

Buka direktori tempat Anda ingin aplikasi dipasang di command prompt. Kami akan membuatnya di desktop.

C:\Users\username\Desktop>cordova 
   create CordovaProject io.cordova.hellocordova CordovaApp
  • CordovaProject adalah nama direktori tempat aplikasi dibuat.

  • io.cordova.hellocordovaadalah nilai domain terbalik default. Anda harus menggunakan nilai domain Anda sendiri jika memungkinkan.

  • CordovaApp adalah judul aplikasi Anda.

Langkah 2 - Menambahkan Platform

Anda perlu membuka direktori proyek Anda di command prompt. Dalam contoh kami, ini adalahCordovaProject. Anda sebaiknya hanya memilih platform yang Anda butuhkan. Untuk dapat menggunakan platform yang ditentukan, Anda harus menginstal SDK platform tertentu. Karena kami mengembangkan di windows, kami dapat menggunakan platform berikut. Kami telah menginstal Android SDK, jadi kami hanya akan menginstal platform android untuk tutorial ini.

C:\Users\username\Desktop\CordovaProject>cordova platform add android

Ada platform lain yang dapat digunakan di OS Windows.

C:\Users\username\Desktop\CordovaProject>cordova platform add wp8

C:\Users\username\Desktop\CordovaProject>cordova platform add amazon-fireos

C:\Users\username\Desktop\CordovaProject>cordova platform add windows

C:\Users\username\Desktop\CordovaProject>cordova platform add blackberry10

C:\Users\username\Desktop\CordovaProject>cordova platform add firefoxos

Jika Anda mengembangkan di Mac, Anda dapat menggunakan -

$ cordova platform add IOS

$ cordova platform add amazon-fireos

$ cordova platform add android

$ cordova platform add blackberry10

$ cordova platform add firefoxos

Anda juga dapat menghapus platform dari proyek Anda dengan menggunakan -

C:\Users\username\Desktop\CordovaProject>cordova platform rm android

Langkah 3 - Membangun dan Menjalankan

Pada langkah ini kita akan membangun aplikasi untuk platform tertentu sehingga kita dapat menjalankannya di perangkat seluler atau emulator.

C:\Users\username\Desktop\CordovaProject>cordova build android

Sekarang kita bisa menjalankan aplikasi kita. Jika Anda menggunakan emulator default, Anda harus menggunakan -

C:\Users\username\Desktop\CordovaProject>cordova emulate android

Jika Anda ingin menggunakan emulator eksternal atau perangkat nyata, Anda harus menggunakan -

C:\Users\username\Desktop\CordovaProject>cordova run android

NOTE - Kami akan menggunakan Genymotion android emulatorkarena lebih cepat dan lebih responsif daripada yang default. Anda dapat menemukan emulatornya di sini . Anda juga dapat menggunakan perangkat nyata untuk pengujian dengan mengaktifkanUSB debuggingdari opsi dan menghubungkannya ke komputer Anda melalui kabel USB. Untuk beberapa perangkat, Anda juga perlu menginstal driver USB.

Setelah kami menjalankan aplikasi, itu akan menginstalnya di platform yang kami tentukan. Jika semuanya selesai tanpa kesalahan, output akan menampilkan layar mulai default aplikasi.

Dalam tutorial kami berikutnya, kami akan menunjukkan cara mengkonfigurasi Aplikasi Cordova.

Itu config.xmlfile adalah tempat di mana kita dapat mengubah konfigurasi aplikasi. Saat kami membuat aplikasi kami di tutorial terakhir, kami menetapkan domain dan nama terbalik. Nilai dapat diubah diconfig.xmlmengajukan. Saat kami membuat aplikasi, file konfigurasi default juga akan dibuat.

Tabel berikut menjelaskan elemen konfigurasi di config.xml.

config.xml Tabel Konfigurasi

S.No Elemen & Detail
1

widget

Aplikasi membalikkan nilai domain yang kami tentukan saat membuat aplikasi.

2

name

Nama aplikasi yang kami tentukan saat membuat aplikasi.

3

description

Deskripsi untuk aplikasi.

4

author

Penulis aplikasi.

5

content

Halaman awal aplikasi. Itu ditempatkan di dalamwww direktori.

6

plugin

Plugin yang sedang diinstal.

7

access

Digunakan untuk mengontrol akses ke domain eksternal. Defaultoriginnilai disetel ke * yang berarti bahwa akses diizinkan ke domain mana pun. Nilai ini tidak akan mengizinkan beberapa URL tertentu dibuka untuk melindungi informasi.

8

allow-intent

Mengizinkan URL tertentu untuk meminta aplikasi untuk dibuka. Sebagai contoh,<allow-intent href = "tel:*" /> akan memungkinkan tautan tel: untuk membuka dialer.

9

platform

Platform untuk membangun aplikasi.

Kita dapat menggunakan API penyimpanan yang tersedia untuk menyimpan data di aplikasi klien. Ini akan membantu penggunaan aplikasi saat pengguna offline dan juga dapat meningkatkan kinerja. Karena tutorial ini untuk pemula, kami akan menunjukkan cara menggunakannyalocal storage. Di salah satu tutorial kami selanjutnya, kami akan menunjukkan kepada Anda plugin lain yang dapat digunakan.

Langkah 1 - Menambahkan Tombol

Kami akan membuat empat tombol di index.htmlmengajukan. Tombol akan ditempatkan di dalamdiv class = "app" elemen.

<button id = "setLocalStorage">SET LOCAL STORAGE</button>
<button id = "showLocalStorage">SHOW LOCAL STORAGE</button>
<button id = "removeProjectFromLocalStorage">REMOVE PROJECT</button>
<button id = "getLocalStorageByKey">GET BY KEY</button>

Ini akan menghasilkan layar berikut -

Langkah 2 - Menambahkan Pendengar Acara

Kebijakan keamanan Cordova tidak mengizinkan kejadian inline, jadi kami akan menambahkan event listener di dalam file index.js. Kami juga akan menetapkanwindow.localStorage ke a localStorage variabel yang akan kita gunakan nanti.

document.getElementById("setLocalStorage").addEventListener("click", setLocalStorage); 
document.getElementById("showLocalStorage").addEventListener("click", showLocalStorage); 
document.getElementById("removeProjectFromLocalStorage").addEventListener 
   ("click", removeProjectFromLocalStorage); 
document.getElementById("getLocalStorageByKey").addEventListener 
   ("click", getLocalStorageByKey);  
var localStorage = window.localStorage;

Langkah 3 - Membuat Fungsi

Sekarang kita perlu membuat fungsi yang akan dipanggil saat tombol diketuk. Fungsi pertama digunakan untuk menambahkan data ke penyimpanan lokal.

function setLocalStorage() { 
   localStorage.setItem("Name", "John"); 
   localStorage.setItem("Job", "Developer"); 
   localStorage.setItem("Project", "Cordova Project"); 
}

Yang berikutnya akan mencatat data yang kami tambahkan ke konsol.

function showLocalStorage() { 
   console.log(localStorage.getItem("Name")); 
   console.log(localStorage.getItem("Job")); 
   console.log(localStorage.getItem("Project")); 
}

Jika kita ketuk SET LOCAL STORAGEtombol, kami akan mengatur tiga item ke penyimpanan lokal. Jika kita ketukSHOW LOCAL STORAGE setelah itu, konsol akan mencatat item yang kita inginkan.

Sekarang mari kita buat fungsi yang akan menghapus proyek dari penyimpanan lokal.

function removeProjectFromLocalStorage() {
   localStorage.removeItem("Project");
}

Jika kita mengklik SHOW LOCAL STORAGE setelah kami menghapus proyek, output akan ditampilkan null nilai untuk bidang proyek.

Kita juga bisa mendapatkan elemen penyimpanan lokal dengan menggunakan key() metode yang akan mengambil indeks sebagai argumen dan mengembalikan elemen dengan nilai indeks yang sesuai.

function getLocalStorageByKey() {
   console.log(localStorage.key(0));
}

Sekarang saat kita mengetuk GET BY KEY tombol, output berikut akan ditampilkan.

CATATAN

Saat kami menggunakan key() metode, konsol akan mencatat job alih-alih name meskipun kami melewati argumen 0untuk mengambil objek pertama. Ini karena penyimpanan lokal menyimpan data dalam urutan abjad.

Tabel berikut menunjukkan semua metode penyimpanan lokal yang tersedia.

S.No Metode & Detail
1

setItem(key, value)

Digunakan untuk mengatur item ke penyimpanan lokal.

2

getItem(key)

Digunakan untuk mendapatkan item dari penyimpanan lokal.

3

removeItem(key)

Digunakan untuk menghapus item dari penyimpanan lokal.

4

key(index)

Digunakan untuk mendapatkan item dengan menggunakan indexdari item tersebut di penyimpanan lokal. Ini membantu mengurutkan item menurut abjad.

5

length()

Digunakan untuk mengambil jumlah item yang ada di penyimpanan lokal.

6

clear()

Digunakan untuk menghapus semua pasangan kunci / nilai dari penyimpanan lokal.

Ada berbagai acara yang dapat digunakan dalam proyek Cordova. Tabel berikut menunjukkan acara yang tersedia.

S.No Acara & Detail
1

deviceReady

Peristiwa ini dipicu setelah Cordova terisi penuh. Ini membantu memastikan bahwa tidak ada fungsi Cordova yang dipanggil sebelum semuanya dimuat.

2

pause

Peristiwa ini dipicu saat aplikasi diletakkan di latar belakang.

3

resume

Peristiwa ini dipicu saat aplikasi dikembalikan dari latar belakang.

4

backbutton

Peristiwa ini dipicu saat tombol kembali ditekan.

5

menubutton

Peristiwa ini dipicu saat tombol menu ditekan.

6

searchbutton

Peristiwa ini dipicu saat tombol pencarian Android ditekan.

7

startcallbutton

Peristiwa ini dipicu ketika tombol mulai panggilan ditekan.

8

endcallbutton

Peristiwa ini dipicu ketika tombol akhiri panggilan ditekan.

9

volumedownbutton

Peristiwa ini dipicu saat tombol volume bawah ditekan.

10

volumeupbutton

Peristiwa ini dipicu saat tombol volume atas ditekan.

Menggunakan Acara

Semua kejadian digunakan dengan cara yang hampir sama. Kami harus selalu menambahkan pendengar acara di kamijs alih-alih inline event calling sejak Cordova Content Security Policytidak mengizinkan Javascript sebaris. Jika kami mencoba memanggil acara sebaris, kesalahan berikut akan ditampilkan.

Cara yang benar untuk bekerja dengan acara adalah dengan menggunakan addEventListener. Kami akan memahami cara menggunakanvolumeupbutton acara melalui contoh.

document.addEventListener("volumeupbutton", callbackFunction, false);  
function callbackFunction() { 
   alert('Volume Up Button is pressed!');
}

Setelah kami menekan volume up tombol, layar akan menampilkan peringatan berikut.

Menangani Tombol Kembali

Kita harus menggunakan tombol kembali Android untuk fungsi aplikasi seperti kembali ke layar sebelumnya. Untuk menerapkan fungsionalitas Anda sendiri, pertama-tama kita harus menonaktifkan tombol kembali yang digunakan untuk keluar dari Aplikasi.

document.addEventListener("backbutton", onBackKeyDown, false);  
function onBackKeyDown(e) { 
   e.preventDefault(); 
   alert('Back Button is Pressed!'); 
}

Sekarang ketika kita menekan tombol kembali Android asli, peringatan akan muncul di layar alih-alih keluar dari aplikasi. Ini dilakukan dengan menggunakane.preventDefault() perintah.

Menangani Tombol Kembali

Anda biasanya ingin menggunakan tombol kembali Android untuk beberapa fungsi aplikasi seperti kembali ke layar sebelumnya. Untuk dapat menerapkan fungsionalitas Anda sendiri, Anda harus menonaktifkan keluar dari aplikasi terlebih dahulu saat tombol kembali ditekan.

document.addEventListener("backbutton", onBackKeyDown, false);  
function onBackKeyDown(e) { 
   e.preventDefault(); 
   alert('Back Button is Pressed!'); 
}

Sekarang ketika kita menekan tombol kembali Android asli, peringatan akan muncul di layar alih-alih keluar dari aplikasi. Ini dilakukan dengan menggunakane.preventDefault().

Cordova Plugman adalah alat baris perintah yang berguna untuk menginstal dan mengelola plugin. Kamu harus menggunakanplugmanjika aplikasi Anda perlu dijalankan pada satu platform tertentu. Jika Anda ingin membuat filecross-platform aplikasi yang harus Anda gunakan cordova-cli yang akan memodifikasi plugin untuk berbagai platform.

Langkah 1 - Menginstal Plugman

Buka command prompt jendela dan jalankan potongan kode berikut untuk menginstal plugman.

C:\Users\username\Desktop\CordovaProject>npm install -g plugman

Langkah 2 - Menginstal Plugin

Untuk memahami cara menginstal plugin Cordova menggunakan plugman, kami akan menggunakan plugin Camera sebagai contoh.

C:\Users\username\Desktop\CordovaProject>plugman  
   install --platform android --project platforms\android  
   --plugin cordova-plugin-camera 
   plugman uninstall --platform android --project platforms\android  
   --plugin cordova-plugin-camera

Kita perlu mempertimbangkan tiga parameter seperti yang ditunjukkan di atas.

  • --platform - platform yang kami gunakan (android, ios, amazon-fireos, wp8, blackberry10).

  • --project- jalur tempat proyek dibangun. Dalam kasus kami, itu benarplatforms\android direktori.

  • --plugin - plugin yang ingin kami instal.

Jika Anda menetapkan parameter yang valid, jendela prompt perintah akan menampilkan keluaran berikut.

Metode Tambahan

Anda dapat menggunakan uninstall metode dengan cara yang sama.

C:\Users\username\Desktop\CordovaProject>plugman uninstall  
   --platform android --project platforms\android --plugin cordova-plugin-camera

Itu command prompt konsol akan menampilkan output berikut.

Plugman menawarkan beberapa metode tambahan yang dapat digunakan. Metode tersebut tercantum di tabel berikut ini.

S.No Metode & Detail
1

install

Digunakan untuk menginstal plugin Cordova.

2

uninstall

Digunakan untuk menghapus plugin Cordova.

3

fetch

Digunakan untuk menyalin plugin Cordova ke lokasi tertentu.

4

prepare

Digunakan untuk memperbarui file konfigurasi untuk membantu dukungan modul JS.

5

adduser

Digunakan untuk menambahkan akun pengguna ke registri.

6

publish

Digunakan untuk menerbitkan plugin ke registri.

7

unpublish

Digunakan untuk membatalkan penerbitan plugin dari registri.

8

search

Digunakan untuk mencari plugin di registri.

9

config

Digunakan untuk konfigurasi pengaturan registri.

10

create

Digunakan untuk membuat plugin khusus.

11

platform

Digunakan untuk menambah atau menghapus platform dari plugin yang dibuat khusus.

Perintah Tambahan

Jika Anda macet, Anda selalu dapat menggunakan plugman -helpperintah. Versi dapat diperiksa dengan menggunakanplugman -v. Untuk mencari plugin, Anda bisa menggunakanplugman search dan terakhir Anda dapat mengubah registri plugin dengan menggunakan plugman config set registry perintah.

CATATAN

Karena Cordova digunakan untuk pengembangan lintas platform, di bab-bab selanjutnya kami akan menggunakannya Cordova CLI dari pada Plugman untuk memasang plugin.

Plugin Cordova ini digunakan untuk memantau status baterai perangkat. Plugin akan memantau setiap perubahan yang terjadi pada baterai perangkat.

Langkah 1 - Memasang Plugin Baterai

Untuk menginstal plugin ini, kita perlu membuka file command prompt jendela dan jalankan kode berikut.

C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-pluginbattery-status

Langkah 2 - Tambahkan Pemroses Acara

Saat Anda membuka file index.js file, Anda akan menemukan file onDeviceReadyfungsi. Di sinilah pendengar acara harus ditambahkan.

window.addEventListener("batterystatus", onBatteryStatus, false);

Langkah 3 - Buat Fungsi Callback

Kami akan membuat onBatteryStatus fungsi panggilan balik di bagian bawah index.js mengajukan.

function onBatteryStatus(info) { 
   alert("BATTERY STATUS:  Level: " + info.level + " isPlugged: " + info.isPlugged); 
}

Saat kami menjalankan aplikasi, peringatan akan dipicu. Saat ini, baterai terisi 100%.

Ketika status diubah, peringatan baru akan ditampilkan. Status baterai menunjukkan bahwa baterai sekarang terisi 99%.

Jika kita mencolokkan perangkat ke pengisi daya, peringatan baru akan menunjukkan bahwa isPlugged nilai diubah menjadi true.

Acara Tambahan

Plugin ini menawarkan dua acara tambahan selain batterystatusperistiwa. Acara ini dapat digunakan dengan cara yang sama sepertibatterystatus peristiwa.

S.No Detail acara
1

batterylow

Peristiwa ini dipicu saat persentase pengisian baterai mencapai nilai rendah. Nilai ini bervariasi dengan perangkat yang berbeda.

2

batterycritical

Peristiwa ini dipicu saat persentase pengisian baterai mencapai nilai kritis. Nilai ini bervariasi dengan perangkat yang berbeda.

Plugin ini digunakan untuk mengambil foto atau menggunakan file dari galeri gambar.

Langkah 1 - Instal Plugin Kamera

Jalankan kode berikut di command prompt jendela untuk menginstal plugin ini.

C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugincamera

Langkah 2 - Menambahkan Tombol dan Gambar

Sekarang, kita akan membuat tombol untuk memanggil kamera dan imgdimana gambar akan ditampilkan setelah diambil. Ini akan ditambahkan keindex.html di dalam div class = "app" elemen.

<button id = "cameraTakePicture">TAKE PICTURE</button>
<img id = "myImage"></img>

Langkah 3 - Menambahkan Pemroses Acara

Pemroses acara ditambahkan di dalam onDeviceReady berfungsi untuk memastikan bahwa Cordova dimuat sebelum kita mulai menggunakannya.

document.getElementById("cameraTakePicture").addEventListener 
   ("click", cameraTakePicture);

Langkah 4 - Menambahkan Fungsi (mengambil foto)

Kami akan membuat cameraTakePicturefungsi yang diteruskan sebagai callback ke event listener kita. Ini akan ditembakkan saat tombol diketuk. Di dalam fungsi ini, kami akan memanggilnavigator.cameraobjek global yang disediakan oleh API plugin. Jika pengambilan gambar berhasil, data akan dikirim keonSuccessfungsi panggilan balik, jika tidak, peringatan dengan pesan kesalahan akan ditampilkan. Kami akan menempatkan kode ini di bagian bawahindex.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); 
   } 
}

Saat kami menjalankan aplikasi dan menekan tombol, kamera asli akan dipicu.

Saat kami mengambil dan menyimpan gambar, itu akan ditampilkan di layar.

Prosedur yang sama dapat digunakan untuk mendapatkan gambar dari sistem file lokal. Satu-satunya perbedaan adalah fungsi yang dibuat pada langkah terakhir. Anda dapat melihat bahwa filesourceType parameter opsional telah ditambahkan.

Langkah 1 B

C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugincamera

Langkah 2 B

<button id = "cameraGetPicture">GET PICTURE</button>

Langkah 3 B

document.getElementById("cameraGetPicture").addEventListener("click", cameraGetPicture);

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

}

Saat kita menekan tombol kedua, sistem file akan terbuka sebagai pengganti kamera sehingga kita dapat memilih gambar yang akan ditampilkan.

Plugin ini menawarkan banyak parameter opsional untuk kustomisasi.

S.No Parameter & Detail
1

quality

Kualitas gambar di kisaran 0-100. Default-nya adalah 50.

2

destinationType

DATA_URL atau 0 Mengembalikan string yang dikodekan base64.

FILE_URI atau 1 Mengembalikan URI file gambar.

NATIVE_URI atau 2 Mengembalikan gambar URI asli.

3

sourceType

PHOTOLIBRARY atau 0 Buka perpustakaan foto.

CAMERA atau 1 Buka kamera asli.

SAVEDPHOTOALBUM atau 2 Buka album foto yang disimpan.

4

allowEdit

Memungkinkan pengeditan gambar.

5

encodingType

JPEG atau 0 Mengembalikan gambar yang dikodekan JPEG.

PNG atau 1 Mengembalikan gambar yang dikodekan PNG.

6

targetWidth

Lebar skala gambar dalam piksel.

7

targetHeight

Tinggi skala gambar dalam piksel.

8

mediaType

PICTURE atau 0 Memungkinkan hanya pemilihan gambar.

VIDEO atau 1 Memungkinkan hanya pemilihan video.

ALLMEDIA atau 2 Memungkinkan semua pemilihan jenis media.

9

correctOrientation

Digunakan untuk mengoreksi orientasi gambar.

10

saveToPhotoAlbum

Digunakan untuk menyimpan gambar ke album foto.

11

popoverOptions

Digunakan untuk mengatur lokasi popover di IOS.

12

cameraDirection

FRONT atau 0 Kamera depan.

BACK atau 1 Kamera belakang.

ALLMEDIA

Plugin ini digunakan untuk mengakses database kontak perangkat. Dalam tutorial ini kami akan menunjukkan kepada Anda cara membuat, menanyakan, dan menghapus kontak.

Langkah 1 - Instal Plugin Kontak

C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugincontacts

Langkah 2 - Menambahkan Tombol

Tombol tersebut akan digunakan untuk memanggil createContactfungsi. Kami akan menempatkannya didiv class = "app" di index.html mengajukan.

<button id = "createContact">ADD CONTACT</button>
<button id = "findContact">FIND CONTACT</button>
<button id = "deleteContact">DELETE CONTACT</button>

Langkah 2 - Tambahkan Pendengar Acara

Buka index.js dan salin cuplikan kode berikut ke onDeviceReady fungsi.

document.getElementById("createContact").addEventListener("click", createContact);
document.getElementById("findContact").addEventListener("click", findContact);
document.getElementById("deleteContact").addEventListener("click", deleteContact);

Langkah 3A - Fungsi Panggilan Balik (navigator.contacts.create)

Sekarang, kami tidak memiliki kontak yang disimpan di perangkat.

Fungsi callback pertama kita akan memanggil navigator.contacts.createmetode di mana kita dapat menentukan data kontak baru. Ini akan membuat kontak dan menetapkannya kemyContactvariabel tetapi tidak akan disimpan di perangkat. Untuk menyimpannya, kita perlu memanggilsave metode dan membuat fungsi panggilan balik sukses dan kesalahan.

function createContact() {
   var myContact = navigator.contacts.create({"displayName": "Test User"});
   myContact.save(contactSuccess, contactError);
    
   function contactSuccess() {
      alert("Contact is saved!");
   }
	
   function contactError(message) {
      alert('Failed because: ' + message);
   }
	
}

Saat kami mengklik ADD CONTACT tombol, kontak baru akan disimpan ke daftar kontak perangkat.

Langkah 3B - Fungsi Panggilan Balik (navigator.contacts.find)

Fungsi panggilan balik kedua kami akan menanyakan semua kontak. Kami akan menggunakannavigator.contacts.findmetode. Objek opsi memiliki parameter filter yang digunakan untuk menentukan filter pencarian.multiple = truedigunakan karena kami ingin mengembalikan semua kontak dari perangkat. Itufield kunci untuk mencari kontak dengan displayName sejak kami menggunakannya saat menyimpan kontak.

Setelah opsi ditetapkan, kami menggunakan findmetode untuk menanyakan kontak. Pesan peringatan akan dipicu untuk setiap kontak yang ditemukan.

function findContacts() {
   var options = new ContactFindOptions();
   options.filter = "";
   options.multiple = true;
   fields = ["displayName"];
   navigator.contacts.find(fields, contactfindSuccess, contactfindError, options);
    
   function contactfindSuccess(contacts) {
      for (var i = 0; i < contacts.length; i++) {
         alert("Display Name = " + contacts[i].displayName);
      }
   }
	
   function contactfindError(message) {
      alert('Failed because: ' + message);
   }
	
}

Saat kami menekan FIND CONTACT tombol, satu sembulan peringatan akan dipicu karena kami hanya menyimpan satu kontak.

Langkah 3C - Fungsi panggilan balik (hapus)

Pada langkah ini, kita akan menggunakan metode find lagi tetapi kali ini kita akan mengatur opsi yang berbeda. Ituoptions.filter disetel untuk mencari itu Test Useryang harus dihapus. SetelahcontactfindSuccess fungsi callback telah mengembalikan kontak yang kita inginkan, kita akan menghapusnya dengan menggunakan remove metode yang membutuhkan keberhasilannya sendiri dan kesalahan panggilan balik.

function deleteContact() {
   var options = new ContactFindOptions();
   options.filter = "Test User";
   options.multiple = false;
   fields = ["displayName"];
   navigator.contacts.find(fields, contactfindSuccess, contactfindError, options);

   function contactfindSuccess(contacts) {
      var contact = contacts[0];
      contact.remove(contactRemoveSuccess, contactRemoveError);

      function contactRemoveSuccess(contact) {
         alert("Contact Deleted");
      }

      function contactRemoveError(message) {
         alert('Failed because: ' + message);
      }
   }

   function contactfindError(message) {
      alert('Failed because: ' + message);
   }
	
}

Sekarang, kami hanya memiliki satu kontak yang disimpan di perangkat. Kami akan menambahkan satu lagi secara manual untuk menunjukkan kepada Anda proses penghapusan.

Kami sekarang akan mengklik DELETE CONTACT tombol untuk menghapus Test User. Jika kita memeriksa kembali daftar kontak, kita akan melihat bahwaTest User tidak ada lagi.

Plugin ini digunakan untuk mendapatkan informasi tentang perangkat pengguna.

Langkah 1 - Menginstal Plugin Perangkat

Untuk menginstal plugin ini, kita perlu menjalankan cuplikan berikut di command prompt.

C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugin-device

Langkah 2 - Menambahkan Tombol

Kami akan menggunakan plugin ini dengan cara yang sama seperti kami menggunakan plugin Cordova lainnya. Mari kita tambahkan tombol diindex.htmlmengajukan. Tombol ini akan digunakan untuk mendapatkan informasi tentang perangkat.

<button id = "cordovaDevice">CORDOVA DEVICE</button>

Langkah 3 - Menambahkan Pemroses Acara

Plugin Cordova tersedia setelah deviceready acara jadi kami akan menempatkan pendengar acara di dalam onDeviceReady berfungsi di index.js.

document.getElementById("cordovaDevice").addEventListener("click", cordovaDevice);

Langkah 4 - Membuat Fungsi

Fungsi berikut akan menunjukkan bagaimana menggunakan semua kemungkinan yang disediakan plugin. Kami akan menempatkannyaindex.js.

function cordovaDevice() {
   alert("Cordova version: " + device.cordova + "\n" +
      "Device model: " + device.model + "\n" +
      "Device platform: " + device.platform + "\n" +
      "Device UUID: " + device.uuid + "\n" +
      "Device version: " + device.version);
}

Saat kami mengklik CORDOVA DEVICE tombol, peringatan akan menampilkan versi Cordova, model perangkat, platform, UUID dan versi perangkat.

Plugin Accelerometer juga disebut device-motion. Ini digunakan untuk melacak gerakan perangkat dalam tiga dimensi.

Langkah 1 - Instal Plugin Accelerometer

Kami akan menginstal plugin ini dengan menggunakan cordova-CLI. Ketik kode berikut dicommand prompt jendela.

C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugin-device-motion

Langkah 2 - Tambahkan Tombol

Pada langkah ini, kami akan menambahkan dua tombol di index.htmlmengajukan. Satu akan digunakan untuk mendapatkan akselerasi saat ini dan yang lainnya akan melihat perubahan akselerasi.

<button id = "getAcceleration">GET ACCELERATION</button>
<button id = "watchAcceleration">WATCH ACCELERATION</button>

Langkah 3 - Tambahkan Pendengar Acara

Sekarang mari kita tambahkan event listener untuk tombol kita onDeviceReady berfungsi di dalam index.js.

document.getElementById("getAcceleration").addEventListener("click", getAcceleration);
document.getElementById("watchAcceleration").addEventListener(
   "click", watchAcceleration);

Langkah 4 - Membuat Fungsi

Sekarang, kita akan membuat dua fungsi. Fungsi pertama akan digunakan untuk mengetahui percepatan arus dan fungsi kedua akan memantau percepatan dan informasi tentang percepatan akan terpicu setiap tiga detik. Kami juga akan menambahkanclearWatch fungsi yang dibungkus oleh setTimeoutberfungsi untuk berhenti menonton akselerasi setelah jangka waktu yang ditentukan. Itufrequency parameter digunakan untuk memicu fungsi panggilan balik setiap tiga detik.

function getAcceleration() {
   navigator.accelerometer.getCurrentAcceleration(
      accelerometerSuccess, accelerometerError);

   function accelerometerSuccess(acceleration) {
      alert('Acceleration X: ' + acceleration.x + '\n' +
         'Acceleration Y: ' + acceleration.y + '\n' +
         'Acceleration Z: ' + acceleration.z + '\n' +
         'Timestamp: '      + acceleration.timestamp + '\n');
   };

   function accelerometerError() {
      alert('onError!');
   };
}

function watchAcceleration() {
   var accelerometerOptions = {
      frequency: 3000
   }
   var watchID = navigator.accelerometer.watchAcceleration(
      accelerometerSuccess, accelerometerError, accelerometerOptions);

   function accelerometerSuccess(acceleration) {
      alert('Acceleration X: ' + acceleration.x + '\n' +
         'Acceleration Y: ' + acceleration.y + '\n' +
         'Acceleration Z: ' + acceleration.z + '\n' +
         'Timestamp: '      + acceleration.timestamp + '\n');

      setTimeout(function() {
         navigator.accelerometer.clearWatch(watchID);
      }, 10000);
   };

   function accelerometerError() {
      alert('onError!');
   };
	
}

Sekarang jika kita menekan GET ACCELERATIONtombol, kita akan mendapatkan nilai percepatan saat ini. Jika kita menekanWATCH ACCELERATIONtombol, peringatan akan dipicu setiap tiga detik. Setelah peringatan ketiga ditampilkanclearWatch fungsi akan dipanggil dan kami tidak akan mendapatkan peringatan lagi karena kami menyetel batas waktu ke 10.000 milidetik.

Kompas digunakan untuk menunjukkan arah relatif terhadap titik mata angin utara geografis.

Langkah 1 - Instal plugin Orientasi Perangkat

Buka command prompt jendela dan jalankan perintah berikut.

C:\Users\username\Desktop\CordovaProject>cordova plugin 
   add cordova-plugindevice-orientation

Langkah 2 - Tambahkan Tombol

Plugin ini mirip dengan accelerationplugin. Mari kita sekarang membuat dua tombolindex.html.

<button id = "getOrientation">GET ORIENTATION</button>
<button id = "watchOrientation">WATCH ORIENTATION</button>

Langkah 3 - Tambahkan Pendengar Acara

Sekarang, kami akan menambahkan event listeners di dalam onDeviceReady berfungsi di index.js.

document.getElementById("getOrientation").addEventListener("click", getOrientation);
document.getElementById("watchOrientation").addEventListener("click", watchOrientation);

Langkah 4 - Membuat Fungsi

Kami akan membuat dua fungsi; fungsi pertama akan menghasilkan percepatan arus dan yang lainnya akan memeriksa perubahan orientasi. Anda dapat melihat bahwa kami menggunakanfrequency pilihan lagi untuk mengawasi perubahan yang terjadi setiap tiga detik.

function getOrientation() {
   navigator.compass.getCurrentHeading(compassSuccess, compassError);

   function compassSuccess(heading) {
      alert('Heading: ' + heading.magneticHeading);
   };

   function compassError(error) {
      alert('CompassError: ' + error.code);
   };
}

function watchOrientation(){
   var compassOptions = {
      frequency: 3000
   }
   var watchID = navigator.compass.watchHeading(compassSuccess, 
      compassError, compassOptions);

   function compassSuccess(heading) {
      alert('Heading: ' + heading.magneticHeading);

      setTimeout(function() {
         navigator.compass.clearWatch(watchID);
      }, 10000);
   };

   function compassError(error) {
      alert('CompassError: ' + error.code);
   };
}

Karena plugin kompas hampir sama dengan plugin akselerasi, kali ini kami akan menunjukkan kode kesalahan kepada Anda. Beberapa perangkat tidak memiliki sensor magnet yang diperlukan untuk kompas bekerja. Jika perangkat Anda tidak memilikinya, kesalahan berikut akan ditampilkan.

Plugin Cordova Dialogs akan memanggil elemen UI dialog asli platform.

Langkah 1 - Menginstal Dialog

Ketik perintah berikut di command prompt jendela untuk menginstal plugin ini.

C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugin-dialogs

Langkah 2 - Tambahkan Tombol

Mari kita buka sekarang index.html dan menambahkan empat tombol, satu untuk setiap jenis dialog.

<button id = "dialogAlert">ALERT</button>
<button id = "dialogConfirm">CONFIRM</button>
<button id = "dialogPrompt">PROMPT</button>
<button id = "dialogBeep">BEEP</button>

Langkah 3 - Tambahkan Pendengar Acara

Sekarang kita akan menambahkan pendengar acara di dalam onDeviceReady berfungsi di index.js. Pendengar akan memanggil fungsi panggilan balik setelah tombol yang sesuai diklik.

document.getElementById("dialogAlert").addEventListener("click", dialogAlert);
document.getElementById("dialogConfirm").addEventListener("click", dialogConfirm);
document.getElementById("dialogPrompt").addEventListener("click", dialogPrompt);
document.getElementById("dialogBeep").addEventListener("click", dialogBeep);

Langkah 4A - Buat Fungsi Peringatan

Karena kita menambahkan empat event listener, sekarang kita akan membuat fungsi callback untuk semuanya di index.js. Yang pertama adalahdialogAlert.

function dialogAlert() {
   var message = "I am Alert Dialog!";
   var title = "ALERT";
   var buttonName = "Alert Button";
   navigator.notification.alert(message, alertCallback, title, buttonName);
   
   function alertCallback() {
      console.log("Alert is Dismissed!");
   }
}

Jika kita mengklik ALERT tombol, kita akan melihat kotak dialog peringatan.

Ketika kita mengklik tombol dialog, output berikut akan ditampilkan di konsol.

Langkah 4B - Buat Fungsi Konfirmasi

Fungsi kedua yang perlu kita buat adalah dialogConfirm fungsi.

function dialogConfirm() {
   var message = "Am I Confirm Dialog?";
   var title = "CONFIRM";
   var buttonLabels = "YES,NO";
   navigator.notification.confirm(message, confirmCallback, title, buttonLabels);

   function confirmCallback(buttonIndex) {
      console.log("You clicked " + buttonIndex + " button!");
   }
	
}

Ketika CONFIRM tombol ditekan, dialog baru akan muncul.

Kami akan mengklik YEStombol untuk menjawab pertanyaan. Output berikut akan ditampilkan di konsol.

Langkah 4C - Buat Fungsi Prompt

Fungsi ketiga adalah dialogPromptfungsi. Ini memungkinkan pengguna untuk mengetik teks ke dalam elemen input dialog.

function dialogPrompt() {
   var message = "Am I Prompt Dialog?";
   var title = "PROMPT";
   var buttonLabels = ["YES","NO"];
   var defaultText = "Default"
   navigator.notification.prompt(message, promptCallback, 
      title, buttonLabels, defaultText);

   function promptCallback(result) {
      console.log("You clicked " + result.buttonIndex + " button! \n" + 
         "You entered " +  result.input1);
   }
	
}

Itu PROMPT Tombol akan memicu kotak dialog seperti pada tangkapan layar berikut.

Di kotak dialog ini, kami memiliki opsi untuk mengetik teks. Kami akan mencatat teks ini di konsol, bersama dengan tombol yang diklik.

Langkah 4D - Buat Fungsi Bip

Yang terakhir adalah dialogBeepfungsi. Ini digunakan untuk memanggil pemberitahuan bip audio. Itutimes parameter akan mengatur jumlah pengulangan untuk sinyal bip.

function dialogBeep() {
   var times = 2;
   navigator.notification.beep(times);
}

Saat kami mengklik BEEP tombol, kita akan mendengar suara notifikasi dua kali, sejak times nilai diatur ke 2.

Plugin ini digunakan untuk memanipulasi sistem file asli pada perangkat pengguna.

Langkah 1 - Menginstal Plugin File

Kita perlu menjalankan kode berikut di command prompt untuk menginstal plugin ini.

C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugin-file

Langkah 2 - Tambahkan Tombol

Dalam contoh ini, kami akan menunjukkan kepada Anda cara membuat file, menulis ke file, membacanya dan menghapusnya. Untuk alasan ini, kami akan membuat empat tombol dalamindex.html. Kami juga akan menambahkantextarea dimana, konten file kami akan ditampilkan.

<button id = "createFile">CREATE FILE</button>
<button id = "writeFile">WRITE FILE</button>
<button id = "readFile">READ FILE</button>
<button id = "removeFile">DELETE FILE</button>
<textarea id = "textarea"></textarea>

Langkah 3 - Tambahkan Pendengar Acara

Kami akan menambahkan event listeners di index.js di dalam onDeviceReady berfungsi untuk memastikan bahwa semuanya telah dimulai sebelum plugin digunakan.

document.getElementById("createFile").addEventListener("click", createFile);
document.getElementById("writeFile").addEventListener("click", writeFile);
document.getElementById("readFile").addEventListener("click", readFile);
document.getElementById("removeFile").addEventListener("click", removeFile);

Langkah 4A - Buat fungsi File

File tersebut akan dibuat di folder root aplikasi pada perangkat. Untuk dapat mengakses folder root yang perlu Anda sediakansuperuserakses ke folder Anda. Dalam kasus kami, jalur ke folder root adalah\data\data\com.example.hello\cache. Saat ini folder tersebut kosong.

Sekarang mari kita tambahkan fungsi yang akan membuat file log.txt. Kami akan menulis kode iniindex.jsdan mengirim permintaan ke sistem file. Metode ini menggunakan WINDOW.TEMPORARY atau WINDOW.PERSISTENT. Ukuran yang diperlukan untuk penyimpanan dinilai dalam byte (dalam kasus kami 5MB).

function createFile() {
   var type = window.TEMPORARY;
   var size = 5*1024*1024;
   window.requestFileSystem(type, size, successCallback, errorCallback)

   function successCallback(fs) {
      fs.root.getFile('log.txt', {create: true, exclusive: true}, function(fileEntry) {
         alert('File creation successfull!')
      }, errorCallback);
   }

   function errorCallback(error) {
      alert("ERROR: " + error.code)
   }
	
}

Sekarang kita bisa menekan CREATE FILE tombol dan peringatan akan mengkonfirmasi bahwa kami berhasil membuat file.

Sekarang, kami dapat memeriksa folder root aplikasi kami lagi dan kami dapat menemukan file baru kami di sana.

Langkah 4B - Fungsi Tulis File

Pada langkah ini, kami akan menulis beberapa teks ke file kami. Kami akan mengirim permintaan lagi ke sistem file, dan kemudian membuat penulis file untuk dapat menulisLorem Ipsum teks yang kami tetapkan ke blob variabel.

function writeFile() {
   var type = window.TEMPORARY;
   var size = 5*1024*1024;
   window.requestFileSystem(type, size, successCallback, errorCallback)

   function successCallback(fs) {
      fs.root.getFile('log.txt', {create: true}, function(fileEntry) {

         fileEntry.createWriter(function(fileWriter) {
            fileWriter.onwriteend = function(e) {
               alert('Write completed.');
            };

            fileWriter.onerror = function(e) {
               alert('Write failed: ' + e.toString());
            };

            var blob = new Blob(['Lorem Ipsum'], {type: 'text/plain'});
            fileWriter.write(blob);
         }, errorCallback);
      }, errorCallback);
   }

   function errorCallback(error) {
      alert("ERROR: " + error.code)
   }
}

Setelah menekan WRITE FILE tombol, peringatan akan memberi tahu kami bahwa penulisan berhasil seperti pada tangkapan layar berikut.

Sekarang kita bisa buka log.txt dan lihat itu Lorem Ipsum tertulis di dalamnya.

Langkah 4C - Baca Fungsi File

Pada langkah ini, kita akan membaca file log.txt dan menampilkannya di textareaelemen. Kami akan mengirimkan permintaan ke sistem file dan mendapatkan objek file, kemudian kami membuatreader. Saat pembaca dimuat, kami akan menetapkan nilai yang dikembalikan ketextarea.

function readFile() {
   var type = window.TEMPORARY;
   var size = 5*1024*1024;
   window.requestFileSystem(type, size, successCallback, errorCallback)

   function successCallback(fs) {
      fs.root.getFile('log.txt', {}, function(fileEntry) {

         fileEntry.file(function(file) {
            var reader = new FileReader();

            reader.onloadend = function(e) {
               var txtArea = document.getElementById('textarea');
               txtArea.value = this.result;
            };
            reader.readAsText(file);
         }, errorCallback);
      }, errorCallback);
   }

   function errorCallback(error) {
      alert("ERROR: " + error.code)
   }
}

Saat kami mengklik READ FILE tombol, teks dari file akan ditulis di dalamnya textarea.

Langkah 4D - Hapus Fungsi File

Dan terakhir kita akan membuat fungsi untuk menghapus log.txt mengajukan.

function removeFile() {
   var type = window.TEMPORARY;
   var size = 5*1024*1024;
   window.requestFileSystem(type, size, successCallback, errorCallback)

   function successCallback(fs) {
      fs.root.getFile('log.txt', {create: false}, function(fileEntry) {

         fileEntry.remove(function() {
            alert('File removed.');
         }, errorCallback);
      }, errorCallback);
   }

   function errorCallback(error) {
      alert("ERROR: " + error.code)
   }
}

Sekarang kita dapat menekan DELETE FILEtombol untuk menghapus file dari folder root aplikasi. Peringatan tersebut akan memberi tahu kami bahwa operasi penghapusan berhasil.

Jika kami memeriksa folder root aplikasi, kami akan melihat bahwa itu kosong.

Plugin ini digunakan untuk mengunggah dan mengunduh file.

Langkah 1 - Menginstal Plugin Transfer File

Kita perlu buka command prompt dan jalankan perintah berikut untuk menginstal plugin.

C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugin-file-transfer

Langkah 2 - Buat Tombol

Di bab ini, kami akan menunjukkan cara mengunggah dan mengunduh file. Mari buat dua tombolindex.html

<button id = "uploadFile">UPLOAD</button>
<button id = "downloadFile">DOWNLOAD</button>

Langkah 3 - Tambahkan Pendengar Acara

Pemroses acara akan dibuat di index.js di dalam onDeviceReadyfungsi. Kami menambahkanclick acara dan callback fungsi.

document.getElementById("uploadFile").addEventListener("click", uploadFile);
document.getElementById("downloadFile").addEventListener("click", downloadFile);

Langkah 4A - Unduh Fungsi

Fungsi ini akan digunakan untuk mengunduh file dari server ke perangkat. Kami mengunggah file kepostimage.orguntuk membuat segalanya lebih sederhana. Anda mungkin ingin menggunakan server Anda sendiri. Fungsi ditempatkan diindex.js dan akan terpicu saat tombol yang sesuai ditekan. uri adalah tautan unduhan server dan fileURI adalah jalur ke folder DCIM di perangkat kami.

function downloadFile() {
   var fileTransfer = new FileTransfer();
   var uri = encodeURI("http://s14.postimg.org/i8qvaxyup/bitcoin1.jpg");
   var fileURL =  "///storage/emulated/0/DCIM/myFile";

   fileTransfer.download(
      uri, fileURL, function(entry) {
         console.log("download complete: " + entry.toURL());
      },
		
      function(error) {
         console.log("download error source " + error.source);
         console.log("download error target " + error.target);
         console.log("download error code" + error.code);
      },
		
      false, {
         headers: {
            "Authorization": "Basic dGVzdHVzZXJuYW1lOnRlc3RwYXNzd29yZA=="
         }
      }
   );
}

Setelah kami menekan DOWNLOAD tombol, file akan diunduh dari postimg.orgserver ke perangkat seluler kami. Kami dapat memeriksa folder yang ditentukan dan melihatnyamyFile disana.

Output konsol akan terlihat seperti ini -

Langkah 4B - Fungsi Unggah

Sekarang mari buat fungsi yang akan mengambil file dan mengunggahnya ke server. Sekali lagi, kami ingin menyederhanakan ini semaksimal mungkin, jadi kami akan menggunakanposttestserver.comserver online untuk pengujian. Nilai uri akan ditautkan untuk memposting keposttestserver.

function uploadFile() {
   var fileURL = "///storage/emulated/0/DCIM/myFile"
   var uri = encodeURI("http://posttestserver.com/post.php");
   var options = new FileUploadOptions();
   options.fileKey = "file";
   options.fileName = fileURL.substr(fileURL.lastIndexOf('/')+1);
   options.mimeType = "text/plain";
   
   var headers = {'headerParam':'headerValue'};
   options.headers = headers;
   var ft = new FileTransfer();
   ft.upload(fileURL, uri, onSuccess, onError, options);

   function onSuccess(r) {
      console.log("Code = " + r.responseCode);
      console.log("Response = " + r.response);
      console.log("Sent = " + r.bytesSent);
   }

   function onError(error) {
      alert("An error has occurred: Code = " + error.code);
      console.log("upload error source " + error.source);
      console.log("upload error target " + error.target);
   }
	
}

Sekarang kita bisa menekan UPLOADtombol untuk memicu fungsi ini. Kami akan mendapatkan output konsol sebagai konfirmasi bahwa pengunggahan berhasil.

Kami juga dapat memeriksa server untuk memastikan bahwa file telah diunggah.

Geolokasi digunakan untuk mendapatkan info tentang lintang dan bujur perangkat.

Langkah 1 - Menginstal Plugin

Kita dapat menginstal plugin ini dengan mengetikkan kode berikut ke command prompt jendela.

C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugin-geolocation

Langkah 2 - Tambahkan Tombol

Dalam tutorial ini kami akan menunjukkan kepada Anda bagaimana mendapatkan posisi saat ini dan bagaimana memperhatikan perubahan. Pertama-tama kita perlu membuat tombol yang akan memanggil fungsi-fungsi ini.

<button id = "getPosition">CURRENT POSITION</button>
<button id = "watchPosition">WATCH POSITION</button>

Langkah 3 - Tambahkan Pendengar Acara

Sekarang kami ingin menambahkan pendengar acara saat perangkat siap. Kami akan menambahkan contoh kode di bawah ini keonDeviceReady berfungsi di index.js.

document.getElementById("getPosition").addEventListener("click", getPosition);
document.getElementById("watchPosition").addEventListener("click", watchPosition);

Langkah 3 - Buat Fungsi

Dua fungsi harus dibuat untuk dua pendengar acara. Satu akan digunakan untuk mendapatkan posisi saat ini dan yang lainnya untuk memantau posisi.

function getPosition() {
   var options = {
      enableHighAccuracy: true,
      maximumAge: 3600000
   }
   var watchID = navigator.geolocation.getCurrentPosition(onSuccess, onError, options);

   function onSuccess(position) {
      alert('Latitude: '          + position.coords.latitude          + '\n' +
         'Longitude: '         + position.coords.longitude         + '\n' +
         'Altitude: '          + position.coords.altitude          + '\n' +
         'Accuracy: '          + position.coords.accuracy          + '\n' +
         'Altitude Accuracy: ' + position.coords.altitudeAccuracy  + '\n' +
         'Heading: '           + position.coords.heading           + '\n' +
         'Speed: '             + position.coords.speed             + '\n' +
         'Timestamp: '         + position.timestamp                + '\n');
   };

   function onError(error) {
      alert('code: '    + error.code    + '\n' + 'message: ' + error.message + '\n');
   }
}

function watchPosition() {
   var options = {
      maximumAge: 3600000,
      timeout: 3000,
      enableHighAccuracy: true,
   }
   var watchID = navigator.geolocation.watchPosition(onSuccess, onError, options);

   function onSuccess(position) {
      alert('Latitude: '          + position.coords.latitude          + '\n' +
         'Longitude: '         + position.coords.longitude         + '\n' +
         'Altitude: '          + position.coords.altitude          + '\n' +
         'Accuracy: '          + position.coords.accuracy          + '\n' +
         'Altitude Accuracy: ' + position.coords.altitudeAccuracy  + '\n' +
         'Heading: '           + position.coords.heading           + '\n' +
         'Speed: '             + position.coords.speed             + '\n' +
         'Timestamp: '         + position.timestamp                + '\n');
   };

   function onError(error) {
      alert('code: '    + error.code    + '\n' +'message: ' + error.message + '\n');
   }
}

Dalam contoh di atas kami menggunakan dua metode - getCurrentPosition dan watchPosition. Kedua fungsi tersebut menggunakan tiga parameter. Begitu kita klikCURRENT POSITION tombol, peringatan akan menunjukkan nilai geolokasi.

Jika kita klik WATCH POSITIONtombol, peringatan yang sama akan dipicu setiap tiga detik. Dengan cara ini kami dapat melacak perubahan pergerakan perangkat pengguna.

CATATAN

Plugin ini menggunakan GPS. Terkadang tidak dapat mengembalikan nilai tepat waktu dan permintaan akan mengembalikan kesalahan batas waktu. Inilah mengapa kami menentukanenableHighAccuracy: true dan maximumAge: 3600000.Ini berarti bahwa jika permintaan tidak diselesaikan tepat waktu, kami akan menggunakan nilai terakhir yang diketahui. Dalam contoh kami, kami menyetel maximumAge ke 3600000 milidetik.

Plugin ini digunakan untuk mendapatkan informasi tentang bahasa lokal pengguna, zona tanggal dan waktu, mata uang, dll.

Langkah 1 - Menginstal Plugin Globalisasi

Buka command prompt dan instal plugin dengan mengetik kode berikut

C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugin-globalization

Langkah 2 - Tambahkan Tombol

Kami akan menambahkan beberapa tombol ke index.html untuk dapat memanggil metode berbeda yang akan kita buat nanti.

<button id = "getLanguage">LANGUAGE</button>
<button id = "getLocaleName">LOCALE NAME</button>
<button id = "getDate">DATE</button>
<button id = "getCurrency">CURRENCY</button>

Langkah 3 - Tambahkan Pendengar Acara

Pendengar acara akan ditambahkan di dalam getDeviceReady berfungsi di index.js file untuk memastikan bahwa aplikasi dan Cordova kami dimuat sebelum kami mulai menggunakannya.

document.getElementById("getLanguage").addEventListener("click", getLanguage);
document.getElementById("getLocaleName").addEventListener("click", getLocaleName);
document.getElementById("getDate").addEventListener("click", getDate);
document.getElementById("getCurrency").addEventListener("click", getCurrency);

Langkah 4A - Fungsi Bahasa

Fungsi pertama yang kami gunakan mengembalikan tag bahasa BCP 47 dari perangkat klien. Kami akan menggunakangetPreferredLanguagemetode. Fungsi ini memiliki dua parameter onSuccess danonError. Kami menambahkan fungsi ini diindex.js.

function getLanguage() {
   navigator.globalization.getPreferredLanguage(onSuccess, onError);

   function onSuccess(language) {
      alert('language: ' + language.value + '\n');
   }

   function onError(){
      alert('Error getting language');
   }
}

Setelah kami menekan LANGUAGE tombol, peringatan akan ditampilkan di layar.

Langkah 4B - Fungsi Lokal

Fungsi ini mengembalikan tag BCP 47 untuk pengaturan lokal klien. Fungsi ini mirip dengan yang kita buat sebelumnya. Satu-satunya perbedaan adalah bahwa kami sedang menggunakangetLocaleName metode kali ini.

function getLocaleName() {
   navigator.globalization.getLocaleName(onSuccess, onError);

   function onSuccess(locale) {
      alert('locale: ' + locale.value);
   }

   function onError(){
      alert('Error getting locale');
   }
}

Saat kami mengklik LOCALE tombol, peringatan akan menampilkan tag lokal kita.

Langkah 4C - Fungsi Tanggal

Fungsi ini digunakan untuk mengembalikan tanggal sesuai dengan lokal klien dan pengaturan zona waktu. date parameter adalah tanggal saat ini dan options parameter adalah opsional.

function getDate() {
   var date = new Date();

   var options = {
      formatLength:'short',
      selector:'date and time'
   }
   navigator.globalization.dateToString(date, onSuccess, onError, options);

   function onSuccess(date) {
      alert('date: ' + date.value);
   }

   function onError(){
      alert('Error getting dateString');
   }
}

Sekarang kami dapat menjalankan aplikasi dan menekan DATE tombol untuk melihat tanggal sekarang.

Fungsi terakhir yang akan kami tampilkan adalah mengembalikan nilai mata uang sesuai dengan pengaturan perangkat klien dan kode mata uang ISO 4217. Anda dapat melihat bahwa konsepnya sama.

function getCurrency() {
   var currencyCode = 'EUR';
   navigator.globalization.getCurrencyPattern(currencyCode, onSuccess, onError);

   function onSuccess(pattern) {
      alert('pattern: '  + pattern.pattern  + '\n' +
         'code: '     + pattern.code     + '\n' +
         'fraction: ' + pattern.fraction + '\n' +
         'rounding: ' + pattern.rounding + '\n' +
         'decimal: '  + pattern.decimal  + '\n' +
         'grouping: ' + pattern.grouping);
   }

   function onError(){
      alert('Error getting pattern');
   }
}

Itu CURRENCY Tombol akan memicu peringatan yang akan menunjukkan pola mata uang pengguna.

Plugin ini menawarkan metode lain. Anda dapat melihat semuanya pada tabel di bawah ini.

metode parameter detailnya
getPreferredLanguage onSuccess, onError Mengembalikan bahasa klien saat ini.
getLocaleName onSuccess, onError Mengembalikan pengaturan lokal klien saat ini.
dateToString tanggal, onSuccess, onError, opsi Mengembalikan tanggal sesuai dengan lokal dan zona waktu klien.
stringToDate dateString, onSuccess, onError, opsi Parsing tanggal sesuai dengan pengaturan klien.
getCurrencyPattern currencyCode, onSuccess, onError Mengembalikan pola mata uang klien.
getDatePattern onSuccess, onError, opsi Mengembalikan pola tanggal klien.
getDateNames onSuccess, onError, opsi Mengembalikan larik nama bulan, minggu atau hari sesuai dengan pengaturan klien.
isDayLightSavingsTime tanggal, successCallback, errorCallback Digunakan untuk menentukan apakah waktu musim panas aktif sesuai dengan zona waktu dan kalender klien.
getFirstDayOfWeek onSuccess, onError Mengembalikan hari pertama dalam seminggu sesuai dengan pengaturan klien.
numberToString nomor, onSuccess, onError, opsi Mengembalikan nomor sesuai dengan pengaturan klien.
stringToNumber string, onSuccess, onError, opsi Mengurai angka sesuai dengan pengaturan klien.
getNumberPattern onSuccess, onError, opsi Mengembalikan pola angka sesuai dengan pengaturan klien.

Plugin ini digunakan untuk membuka browser web di dalam aplikasi Cordova.

Langkah 1 - Menginstal Plugin

Kita perlu menginstal plugin ini di command prompt jendela sebelum kami dapat menggunakannya.

C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugin-inappbrowser

Langkah 2 - Tombol Tambah

Kami akan menambahkan satu tombol yang akan digunakan untuk membuka inAppBrowser jendela masuk index.html.

Langkah 3 - Tambahkan Pemroses Acara

Sekarang mari tambahkan event listener untuk tombol kita di onDeviceReady berfungsi di index.js.

document.getElementById("openBrowser").addEventListener("click", openBrowser);

Langkah 4 - Buat Fungsi

Pada langkah ini kami membuat fungsi yang akan membuka browser di dalam aplikasi kami. Kami menugaskannya keref variabel yang bisa kita gunakan nanti untuk menambahkan event listener.

function openBrowser() {
   var url = 'https://cordova.apache.org';
   var target = '_blank';
   var options = "location = yes"
   var ref = cordova.InAppBrowser.open(url, target, options);
   
   ref.addEventListener('loadstart', loadstartCallback);
   ref.addEventListener('loadstop', loadstopCallback);
   ref.addEventListener('loaderror', loaderrorCallback);
   ref.addEventListener('exit', exitCallback);

   function loadstartCallback(event) {
      console.log('Loading started: '  + event.url)
   }

   function loadstopCallback(event) {
      console.log('Loading finished: ' + event.url)
   }

   function loaderrorCallback(error) {
      console.log('Loading error: ' + error.message)
   }

   function exitCallback() {
      console.log('Browser is closed...')
   }
}

Jika kita menekan BROWSER tombol, kita akan melihat output berikut di layar.

Konsol juga akan mendengarkan acara. loadstart acara akan aktif ketika URL mulai memuat dan loadstopakan aktif saat URL dimuat. Kita bisa melihatnya di konsol.

Setelah kami menutup browser, exit acara akan menyala.

Ada opsi lain yang memungkinkan untuk jendela InAppBrowser. Kami akan menjelaskannya pada tabel di bawah.

S.No opsi & detail
1

location

Digunakan untuk menghidupkan atau mematikan bilah lokasi browser. Nilai adalahyes atau no.

2

hidden

Digunakan untuk menyembunyikan atau menampilkan inAppBrowser. Nilai adalahyes atau no.

3

clearCache

Digunakan untuk membersihkan cache cookie browser. Nilai adalahyes atau no.

4

clearsessioncache

Digunakan untuk menghapus cache cookie sesi. Nilai adalahyes atau no.

5

zoom

Digunakan untuk menyembunyikan atau menampilkan kontrol zoom browser Android. Nilai adalahyes atau no.

6

hardwareback

yes untuk menggunakan tombol kembali perangkat keras untuk menavigasi kembali ke riwayat browser. no untuk menutup browser setelah tombol kembali diklik.

Kita bisa gunakan ref(referensi) untuk beberapa fungsi lainnya. Kami akan menunjukkan contoh singkatnya. Untuk menghapus pendengar acara kita dapat menggunakan -

ref.removeEventListener(eventname, callback);

Untuk menutup InAppBrowser kita bisa menggunakan -

ref.close();

Jika kami membuka jendela tersembunyi, kami dapat menunjukkannya -

ref.show();

Bahkan kode JavaScript dapat disuntikkan ke InAppBrowser -

var details = "javascript/file/url"
ref.executeScript(details, callback);

Konsep yang sama dapat digunakan untuk memasukkan CSS -

var details = "css/file/url"
ref.inserCSS(details, callback);

Plugin media Cordova digunakan untuk merekam dan memutar suara audio di aplikasi Cordova.

Langkah 1 - Menginstal Plugin Media

Plugin media dapat diinstal dengan menjalankan kode berikut di command prompt jendela.

C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugin-media

Langkah 2 - Tambahkan Tombol

Dalam tutorial ini, kami akan membuat pemutar audio sederhana. Mari buat tombol yang kita butuhkanindex.html.

<button id = "playAudio">PLAY</button>
<button id = "pauseAudio">PAUSE</button>
<button id = "stopAudio">STOP</button>
<button id = "volumeUp">VOLUME UP</button>
<button id = "volumeDown">VOLUME DOWN</button>

Langkah 3 - Tambahkan Pendengar Acara

Sekarang kita perlu menambahkan pendengar acara untuk tombol di dalamnya onDeviceReady berfungsi di dalam index.js.

document.getElementById("playAudio").addEventListener("click", playAudio);
document.getElementById("pauseAudio").addEventListener("click", pauseAudio);
document.getElementById("stopAudio").addEventListener("click", stopAudio);
document.getElementById("volumeUp").addEventListener("click", volumeUp);
document.getElementById("volumeDown").addEventListener("click", volumeDown);

Langkah 4A - Fungsi Putar

Fungsi pertama yang akan kita tambahkan adalah playAudio. Kami sedang mendefinisikanmyMediadi luar fungsi karena kita ingin menggunakannya dalam fungsi yang akan ditambahkan nanti (jeda, stop, volumeUp dan volumeDown). Kode ini ditempatkan diindex.js mengajukan.

var myMedia = null;
function playAudio() {
   var src = "/android_asset/www/audio/piano.mp3";

   if(myMedia === null) {
      myMedia = new Media(src, onSuccess, onError);

      function onSuccess() {
         console.log("playAudio Success");
      }

      function onError(error) {
         console.log("playAudio Error: " + error.code);
      }
   }
   myMedia.play();
}

Kita bisa klik PLAY tombol untuk memulai musik piano dari src jalan.

Langkah 4B - Fungsi Jeda dan Hentikan

Fungsi selanjutnya yang kita butuhkan adalah pauseAudio dan stopAudio.

function pauseAudio() {
   if(myMedia) {
      myMedia.pause();
   }
}

function stopAudio() {
   if(myMedia) {
      myMedia.stop(); 
   }
   myMedia = null;
}

Sekarang kita bisa menjeda atau menghentikan suara piano dengan mengklik PAUSE atau STOP tombol.

Langkah 4C - Fungsi Volume

Untuk mengatur volume, kita bisa menggunakan setVolumemetode. Metode ini mengambil parameter dengan nilai dari0 untuk 1. Kami akan menetapkan nilai awal menjadi0.5.

var volumeValue = 0.5;
function volumeUp() {
   if(myMedia && volumeValue < 1) {
      myMedia.setVolume(volumeValue += 0.1);
   }
}

function volumeDown() {
   if(myMedia && volumeValue > 0) {
      myMedia.setVolume(volumeValue -= 0.1);
   }
}

Setelah kami menekan VOLUME UP atau VOLUME DOWN kita dapat mengubah nilai volume dengan 0.1.

Tabel berikut menunjukkan metode lain yang disediakan plugin ini.

S.No Metode & Detail
1

getCurrentPosition

Mengembalikan posisi audio saat ini.

2

getDuration

Mengembalikan durasi audio.

3

play

Digunakan untuk memulai atau melanjutkan audio.

4

pause

Digunakan untuk menjeda audio.

5

release

Merilis sumber daya audio sistem operasi yang mendasarinya.

6

seekTo

Digunakan untuk mengubah posisi audio.

7

setVolume

Digunakan untuk mengatur volume audio.

8

startRecord

Mulailah merekam file audio.

9

stopRecord

Berhenti merekam file audio.

10

stop

Berhenti memutar file audio.

Plugin ini digunakan untuk mengakses opsi pengambilan perangkat.

Langkah 1 - Menginstal Plugin Media Capture

Untuk menginstal plugin ini, kami akan membuka command prompt dan jalankan kode berikut -

C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugin-media-capture

Langkah 2 - Tambahkan Tombol

Karena kami ingin menunjukkan cara menangkap audio, gambar, dan video, kami akan membuat tiga tombol di index.html.

<button id = "audioCapture">AUDIO</button>
<button id = "imageCapture">IMAGE</button>
<button id = "videoCapture">VIDEO</button>

Langkah 3 - Tambahkan Pendengar Acara

Langkah selanjutnya adalah menambahkan pendengar acara di dalamnya onDeviceReady di index.js.

document.getElementById("audioCapture").addEventListener("click", audioCapture);
document.getElementById("imageCapture").addEventListener("click", imageCapture);
document.getElementById("videoCapture").addEventListener("click", videoCapture);

Langkah 4A - Tangkap Fungsi Audio

Fungsi panggilan balik pertama di index.js adalah audioCapture. Untuk memulai perekam suara, kami akan menggunakancaptureAudiometode. Kami menggunakan dua opsi -limit akan memungkinkan perekaman hanya satu klip audio per operasi pengambilan tunggal dan duration adalah jumlah detik klip suara.

function audioCapture() {
   var options = {
      limit: 1,
      duration: 10
   };
   navigator.device.capture.captureAudio(onSuccess, onError, options);

   function onSuccess(mediaFiles) {
      var i, path, len;
      for (i = 0, len = mediaFiles.length; i < len; i += 1) {
         path = mediaFiles[i].fullPath;
         console.log(mediaFiles);
      }
   }

   function onError(error) {
      navigator.notification.alert('Error code: ' + error.code, null, 'Capture Error');
   }
}

Saat kami menekan AUDIO tombol, perekam suara akan terbuka.

Konsol akan menampilkan larik kembali objek yang ditangkap pengguna.

Langkah 4B - Fungsi Tangkap Gambar

Fungsi untuk menangkap gambar akan sama dengan yang terakhir. Satu-satunya perbedaan adalah bahwa kami sedang menggunakancaptureImage metode kali ini.

function imageCapture() {
   var options = {
      limit: 1
   };
   navigator.device.capture.captureImage(onSuccess, onError, options);

   function onSuccess(mediaFiles) {
      var i, path, len;
      for (i = 0, len = mediaFiles.length; i < len; i += 1) {
         path = mediaFiles[i].fullPath;
         console.log(mediaFiles);
      }
   }

   function onError(error) {
      navigator.notification.alert('Error code: ' + error.code, null, 'Capture Error');
   }
}

Sekarang kita bisa klik IMAGE tombol untuk memulai kamera.

Saat kita mengambil gambar, konsol akan mencatat array dengan objek gambar.

Langkah 4C - Fungsi Capture Video

Mari ulangi konsep yang sama untuk merekam video. Kami akan menggunakanvideoCapture metode kali ini.

function videoCapture() {
   var options = {
      limit: 1,
      duration: 10
   };
   navigator.device.capture.captureVideo(onSuccess, onError, options);

   function onSuccess(mediaFiles) {
      var i, path, len;
      for (i = 0, len = mediaFiles.length; i < len; i += 1) {
         path = mediaFiles[i].fullPath;
         console.log(mediaFiles);
      }
   }

   function onError(error) {
      navigator.notification.alert('Error code: ' + error.code, null, 'Capture Error');
   }
}

Jika kita menekan VIDEO tombol, kamera akan terbuka dan kita dapat merekam video.

Setelah video disimpan, konsol akan mengembalikan array sekali lagi. Kali ini dengan objek video di dalamnya.

Plugin ini memberikan informasi tentang jaringan perangkat.

Langkah 1 - Memasang Plugin Informasi Jaringan

Untuk menginstal plugin ini, kami akan membuka command prompt dan jalankan kode berikut -

C:\Users\username\Desktop\CordovaProject>cordova plugin 
   add cordova-plugin-network-information

Langkah 2 - Tambahkan Tombol

Mari buat satu tombol index.html yang akan digunakan untuk mendapatkan info tentang jaringan.

<button id = "networkInfo">INFO</button>

Langkah 3 - Tambahkan Pendengar Acara

Kami akan menambahkan tiga pendengar acara di dalam onDeviceReady berfungsi di index.js. Satu akan mendengarkan klik pada tombol yang kita buat sebelumnya dan dua lainnya akan mendengarkan perubahan status koneksi.

document.getElementById("networkInfo").addEventListener("click", networkInfo);
document.addEventListener("offline", onOffline, false);
document.addEventListener("online", onOnline, false);

Langkah 4 - Membuat Fungsi

networkInfoFungsi akan mengembalikan info tentang koneksi jaringan saat ini setelah tombol diklik. Kami menelepontypemetode. Fungsi lainnya adalahonOffline dan onOnline. Fungsi-fungsi ini mendengarkan perubahan koneksi dan setiap perubahan akan memicu pesan peringatan yang sesuai.

function networkInfo() {
   var networkState = navigator.connection.type;
   var states = {};
   states[Connection.UNKNOWN]  = 'Unknown connection';
   states[Connection.ETHERNET] = 'Ethernet connection';
   states[Connection.WIFI]     = 'WiFi connection';
   states[Connection.CELL_2G]  = 'Cell 2G connection';
   states[Connection.CELL_3G]  = 'Cell 3G connection';
   states[Connection.CELL_4G]  = 'Cell 4G connection';
   states[Connection.CELL]     = 'Cell generic connection';
   states[Connection.NONE]     = 'No network connection';
   alert('Connection type: ' + states[networkState]);
}

function onOffline() {
   alert('You are now offline!');
}

function onOnline() {
   alert('You are now online!');
}

Saat kami memulai aplikasi yang terhubung ke jaringan, onOnline fungsi akan memicu peringatan.

Jika kita menekan INFO tombol peringatan akan menunjukkan status jaringan kami.

Jika kami memutuskan sambungan dari jaringan, onOffline fungsi akan dipanggil.

Plugin ini digunakan untuk menampilkan layar splash pada peluncuran aplikasi.

Langkah 1 - Menginstal Plugin Splash Screen

Plugin layar splash dapat diinstal di command prompt jendela dengan menjalankan kode berikut.

C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugin-splashscreen

Langkah 2 - Tambahkan Splash Screen

Menambahkan splash screen berbeda dengan menambahkan plugin Cordova lainnya. Kita perlu bukaconfig.xml dan tambahkan cuplikan kode berikut di dalam widget elemen.

Cuplikan pertama adalah SplashScreen. Memilikivalue properti yang merupakan nama gambar di platform/android/res/drawable- folder. Cordova menawarkan defaultscreen.pnggambar yang kami gunakan dalam contoh ini, tetapi Anda mungkin ingin menambahkan gambar Anda sendiri. Yang penting adalah menambahkan gambar untuk tampilan potret dan lanskap dan juga untuk menutupi ukuran layar yang berbeda.

<preference name = "SplashScreen" value = "screen" />

Potongan kedua yang perlu kita tambahkan adalah SplashScreenDelay. Kami sedang mengaturvalue untuk 3000 untuk menyembunyikan layar pembuka setelah tiga detik.

<preference name = "SplashScreenDelay" value = "3000" />

Preferensi terakhir adalah opsional. Jika nilai disetel ketrue, gambar tidak akan ditarik agar pas dengan layar. Jika diatur kefalse, itu akan diregangkan.

<preference name = "SplashMaintainAspectRatio" value = "true" />

Sekarang ketika kita menjalankan aplikasi, kita akan melihat layar splash.

Plugin ini digunakan untuk menghubungkan ke fungsi getaran perangkat.

Langkah 1 - Memasang Plugin Getaran

Kami dapat menginstal plugin ini di command prompt jendela dengan menjalankan kode berikut -

C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugin-vibration

Langkah 2 - Tambahkan Tombol

Setelah plugin terinstal, kita dapat menambahkan tombol index.html yang nantinya akan digunakan untuk memicu getaran.

<button id = "vibration">VIBRATION</button>
<button id = "vibrationPattern">PATTERN</button>

Langkah 3 - Tambahkan Pendengar Acara

Sekarang kita akan menambahkan pendengar acara di dalamnya onDeviceReady di index.js.

document.getElementById("vibration").addEventListener("click", vibration);
document.getElementById("vibrationPattern").addEventListener("click", vibrationPattern);

Langkah 4 - Buat Fungsi

Plugin ini sangat mudah digunakan. Kami akan membuat dua fungsi.

function vibration() {
   var time = 3000;
   navigator.vibrate(time);
}

function vibrationPattern() {
   var pattern = [1000, 1000, 1000, 1000];
   navigator.vibrate(pattern);
}

Fungsi pertama adalah mengambil parameter waktu. Parameter ini digunakan untuk mengatur durasi getaran. Perangkat akan bergetar selama tiga detik setelah kita tekanVIBRATION tombol.

Fungsi kedua menggunakan patternparameter. Larik ini akan meminta perangkat bergetar selama satu detik, lalu menunggu selama satu detik, lalu mengulangi prosesnya lagi.

Plugin ini memungkinkan kami menerapkan kebijakan daftar putih untuk navigasi aplikasi. Saat kami membuat proyek Cordova baru, filewhitelistplugin diinstal dan diimplementasikan secara default. Anda dapat membukaconfig.xml file untuk dilihat allow-intent pengaturan default yang disediakan oleh Cordova.

Daftar Putih Navigasi

Dalam contoh sederhana di bawah ini kami mengizinkan tautan ke beberapa URL eksternal. Kode ini ditempatkan diconfig.xml. Navigasi kefile:// URL diizinkan secara default.

<allow-navigation href = "http://example.com/*" />

Tanda asterix, *, digunakan untuk memungkinkan navigasi ke beberapa nilai. Dalam contoh di atas, kami mengizinkan navigasi ke semua sub-domain dariexample.com. Hal yang sama dapat diterapkan pada protokol atau awalan ke host.

<allow-navigation href = "*://*.example.com/*" />

Daftar Putih Maksud

Ada juga allow-intentelemen yang digunakan untuk menentukan URL mana yang diizinkan untuk membuka sistem. Anda bisa lihat diconfig.xml bahwa Cordova telah mengizinkan sebagian besar tautan yang dibutuhkan untuk kami.

Daftar Putih Permintaan Jaringan

Saat Anda melihat ke dalam config.xml file, ada <access origin="*" />elemen. Elemen ini memungkinkan semua permintaan jaringan ke aplikasi kita melalui kait Cordova. Jika Anda hanya ingin mengizinkan permintaan tertentu, Anda dapat menghapusnya dari config.xml dan menyetelnya sendiri.

Prinsip yang sama digunakan seperti pada contoh sebelumnya.

<access origin = "http://example.com" />

Ini akan mengizinkan semua permintaan jaringan dari http://example.com.

Kebijakan Keamanan Konten

Anda dapat melihat kebijakan keamanan saat ini untuk aplikasi Anda di dalam head elemen di index.html.

<meta http-equiv = "Content-Security-Policy" content = "default-src 
   'self' data: gap: https://ssl.gstatic.com 'unsafe-eval'; style-src 
   'self' 'unsafe-inline'; media-src *">

Ini adalah konfigurasi default. Jika Anda ingin mengizinkan semuanya dari asal yang sama danexample.com, lalu Anda dapat menggunakan -

<meta http-equiv = "Content-Security-Policy" content = "default-src 'self' foo.com">

Anda juga dapat mengizinkan semuanya, tetapi membatasi CSS dan JavaScript ke asal yang sama.

<meta http-equiv = "Content-Security-Policy" content = "default-src *; 
   style-src 'self' 'unsafe-inline'; script-src 'self' 
   'unsafe-inline' 'unsafe-eval'">

Karena ini adalah tutorial pemula, kami merekomendasikan opsi Cordova default. Setelah Anda terbiasa dengan Cordova, Anda dapat mencoba beberapa nilai yang berbeda.

Cordova digunakan untuk membuat aplikasi seluler hybrid, jadi Anda perlu mempertimbangkan ini sebelum memilihnya untuk proyek Anda. Berikut adalah praktik terbaik untuk pengembangan aplikasi Cordova.

Aplikasi Halaman Tunggal

Ini adalah desain yang direkomendasikan untuk semua aplikasi Cordova. SPA menggunakan router sisi klien dan navigasi dimuat di satu halaman (biasanyaindex.html). Perutean ditangani melalui AJAX. Jika Anda telah mengikuti tutorial kami, Anda mungkin memperhatikan bahwa hampir setiap plugin Cordova perlu menunggu hingga perangkat siap sebelum dapat digunakan. Desain SPA akan meningkatkan kecepatan pemuatan dan kinerja keseluruhan.

Sentuh Acara

Karena Cordova digunakan untuk dunia seluler, maka wajar digunakan touchstart dan touchend acara, bukan clickacara. Peristiwa klik memiliki penundaan 300 md, sehingga klik tidak terasa asli. Di sisi lain, acara sentuh tidak didukung di setiap platform. Anda harus mempertimbangkan hal ini sebelum memutuskan apa yang akan digunakan.

Animasi

Anda harus selalu menggunakan akselerasi perangkat keras CSS Transitions alih-alih animasi JavaScript karena akan bekerja lebih baik di perangkat seluler.

Penyimpanan

Gunakan penyimpanan caching sebanyak mungkin. Koneksi jaringan seluler biasanya buruk, jadi Anda harus meminimalkan panggilan jaringan di dalam aplikasi Anda. Anda juga harus menangani status offline aplikasi, karena akan ada kalanya perangkat pengguna offline.

Menggulir

Sebagian besar waktu, bagian lambat pertama di dalam aplikasi Anda adalah daftar gulir. Ada beberapa cara untuk meningkatkan kinerja pengguliran aplikasi. Rekomendasi kami adalah menggunakan scrolling asli. Jika ada banyak item dalam daftar, Anda harus memuatnya sebagian. Gunakan loader bila perlu.

Gambar-gambar

Gambar juga dapat memperlambat aplikasi seluler. Anda harus menggunakan sprite gambar CSS jika memungkinkan. Cobalah untuk menyesuaikan gambar dengan sempurna alih-alih menskalakannya.

Gaya CSS

Anda harus menghindari bayangan dan gradien, karena mereka memperlambat waktu rendering halaman.

Penyederhanaan

DOM browser lambat, jadi Anda harus mencoba meminimalkan manipulasi DOM dan jumlah elemen DOM.

Menguji

Pastikan Anda menguji aplikasi Anda di sebanyak mungkin perangkat dan versi sistem operasi. Jika aplikasi berfungsi dengan sempurna di satu perangkat, itu tidak berarti bahwa aplikasi akan berfungsi di perangkat atau platform lain.