Deskripsi
Gunakan chrome.documentScan
API untuk menemukan dan mengambil gambar dari pemindai dokumen yang terhubung ke perangkat.
Document Scan API dirancang untuk memungkinkan aplikasi dan ekstensi melihat konten dokumen kertas pada pemindai dokumen yang terhubung.
Izin
documentScan
Ketersediaan
Konsep dan penggunaan
API ini mendukung dua cara pemindaian dokumen. Jika kasus penggunaan Anda dapat berfungsi dengan pemindai apa pun dan tidak memerlukan kontrol konfigurasi, gunakan metode scan()
. Kasus penggunaan yang lebih rumit memerlukan kombinasi metode, yang hanya didukung di Chrome 124 dan yang lebih baru.
Pemindaian sederhana
Untuk kasus penggunaan sederhana, yang berarti kasus penggunaan yang dapat berfungsi dengan pemindai apa pun dan tidak memerlukan kontrol konfigurasi, panggil scan()
. Metode ini mengambil objek ScanOptions
dan menampilkan Promise yang diselesaikan dengan objek ScanResults
. Kemampuan opsi ini terbatas pada jumlah pemindaian dan jenis MIME yang akan diterima oleh pemanggil. Hasil pindaian ditampilkan sebagai URL
untuk ditampilkan dalam tag <img>
untuk antarmuka pengguna.
Pemindaian kompleks
Pemindaian kompleks dilakukan dalam tiga fase seperti yang dijelaskan di bagian ini. Ringkasan ini tidak menjelaskan setiap argumen metode atau setiap properti yang ditampilkan dalam respons. Tujuannya hanya untuk memberi Anda panduan umum dalam menulis kode pemindai.
Discovery
Panggil
getScannerList()
. Pemindai yang tersedia ditampilkan dalam Promise yang di-resolve denganGetScannerListResponse
.- Objek respons berisi array objek
ScannerInfo
. - Array dapat berisi beberapa entri untuk satu pemindai jika pemindai tersebut mendukung beberapa protokol atau metode koneksi.
- Objek respons berisi array objek
Pilih pemindai dari array yang ditampilkan dan simpan nilai properti
scannerId
-nya.Gunakan properti masing-masing objek
ScannerInfo
untuk membedakan beberapa objek untuk pemindai yang sama. Objek dari pemindai yang sama akan memiliki nilai yang sama untuk propertideviceUuid
.ScannerInfo
juga berisi propertiimageFormats
yang berisi array jenis gambar yang didukung.
Konfigurasi pemindai
Panggil
openScanner()
, dengan meneruskan ID pemindai yang disimpan. Metode ini menampilkan Promise yang di-resolve denganOpenScannerResponse
. Objek respons berisi:Properti
scannerHandle
, yang perlu Anda simpan.Properti opsi yang berisi properti khusus pemindai, yang perlu Anda tetapkan. Lihat Mengambil opsi pemindai untuk mengetahui informasi selengkapnya.
(Opsional) Jika Anda memerlukan pengguna untuk memberikan nilai untuk opsi pemindai, buat antarmuka pengguna. Anda akan memerlukan opsi pemindai yang diberikan oleh langkah sebelumnya, dan Anda harus mengambil grup opsi yang diberikan oleh pemindai. Lihat Buat antarmuka pengguna untuk mengetahui informasi selengkapnya.
Buat array objek
OptionSetting
menggunakan nilai yang disediakan pengguna atau nilai terprogram. Lihat Menetapkan opsi pemindai untuk mengetahui informasi selengkapnya.Teruskan array objek
OptionSetting
kesetOptions()
untuk menyetel opsi pemindai. Metode ini menampilkan Promise yang di-resolve denganSetOptionsResponse
. Objek ini berisi versi terbaru opsi pemindai yang diambil pada langkah 1 konfigurasi pemindai.Karena mengubah satu opsi dapat mengubah batasan pada opsi lain, Anda mungkin perlu mengulangi langkah-langkah ini beberapa kali.
Memindai
Buat objek
StartScanOptions
dan teruskan kestartScan()
. Metode ini menampilkan Promise yang di-resolve denganStartScanResponse
. Propertijob
-nya adalah handle yang akan Anda gunakan untuk membaca data pemindaian atau membatalkan pemindaian.Teruskan handle tugas ke
readScanData()
. Metode ini menampilkan Promise yang diselesaikan dengan objekReadScanDataResponse
. Jika data berhasil dibaca, propertiresult
-nya sama denganSUCCESS
dan propertidata
-nya berisiArrayBuffer
dengan bagian pemindaian. Perhatikan bahwaestimatedCompletion
berisi perkiraan persentase total data yang telah dikirimkan sejauh ini.Ulangi langkah sebelumnya hingga properti
result
sama denganEOF
atau error.
Saat akhir pemindaian tercapai, panggil
closeScanner()
dengan handle pemindai yang disimpan di langkah
3. Metode ini menampilkan Promise yang di-resolve dengan
CloseScannerResponse
. Memanggil
cancelScan()
kapan saja setelah tugas dibuat akan
mengakhiri pemindaian.
Objek respons
Semua metode menampilkan Promise yang diselesaikan dengan objek respons dari beberapa jenis.
Sebagian besar berisi properti result
yang nilainya adalah anggota
OperationResult
. Beberapa properti objek respons
tidak akan berisi nilai kecuali jika nilai result
memiliki nilai tertentu. Hubungan
ini dijelaskan dalam referensi untuk setiap objek respons.
Misalnya, OpenScannerResponse.scannerHandle
hanya akan memiliki nilai jika
OpenScannerResponse.result
sama dengan SUCCESS
.
Opsi pemindai
Opsi pemindai sangat bervariasi menurut perangkat. Akibatnya, opsi pemindai tidak dapat ditampilkan langsung dalam documentScan API. Untuk mengatasi
hal ini, OpenScannerResponse
(diambil menggunakan
openScanner()
) dan
SetOptionsResponse
(objek respons untuk
setOptions()
) berisi properti options
yang merupakan
objek yang berisi opsi khusus pemindai. Setiap opsi adalah pemetaan nilai kunci
dengan kunci berupa opsi khusus perangkat dan nilai berupa instance
ScannerOption
.
Strukturnya umumnya terlihat seperti ini:
{
"key1": { scannerOptionInstance }
"key2": { scannerOptionInstance }
}
Misalnya, bayangkan pemindai yang menampilkan opsi bernama "source" dan "resolution". Struktur objek options
yang ditampilkan akan terlihat seperti contoh berikut. Agar lebih sederhana, hanya sebagian respons ScannerOption
yang ditampilkan.
{
"source": {
"name": "source",
"type": OptionType.STRING,
...
},
"resolution": {
"name": "resolution",
"type": OptionType.INT,
...
},
...
}
Membangun antarmuka pengguna
Meskipun tidak diperlukan untuk menggunakan API ini, Anda mungkin ingin pengguna memilih nilai untuk
opsi tertentu. Hal ini memerlukan antarmuka pengguna. Gunakan
OpenScannerResponse
(dibuka oleh
openScanner()
) untuk mengambil opsi pemindai terlampir seperti yang dijelaskan di bagian sebelumnya.
Beberapa pemindai mengelompokkan opsi dengan cara khusus perangkat. Grup ini tidak memengaruhi perilaku opsi, tetapi karena grup ini mungkin disebutkan dalam dokumentasi produk pemindai, grup tersebut harus ditampilkan kepada pengguna. Anda dapat mengambil grup ini dengan memanggil getOptionGroups()
. Metode ini menampilkan
Promise yang diselesaikan dengan objek
GetOptionGroupsResponse
. Properti groups
berisi array grup khusus pemindai. Gunakan informasi dalam
grup ini untuk mengatur opsi di
OpenScannerResponse
untuk ditampilkan.
{
scannerHandle: "123456",
result: SUCCESS,
groups: [
{
title: "Standard",
members: [ "resolution", "mode", "source" ]
}
]
}
Seperti yang dinyatakan di bagian Konfigurasi pemindai, mengubah satu opsi dapat mengubah batasan pada opsi lain. Itulah sebabnya
setOptionsResponse
(objek respons untuk
setOptions()
) berisi properti options
lain. Gunakan
ini untuk memperbarui antarmuka pengguna. Kemudian, ulangi sesuai kebutuhan hingga semua opsi ditetapkan.
Menetapkan opsi pemindai
Tetapkan opsi pemindai dengan meneruskan array objek
OptionSetting
ke
setOptions()
. Sebagai contoh, lihat bagian Memindai satu halaman berukuran letter berikut.
Contoh
Mengambil halaman sebagai blob
Contoh ini menunjukkan salah satu cara untuk mengambil halaman dari pemindai sebagai blob dan menunjukkan penggunaan startScan()
dan readScanData()
menggunakan nilai OperationResult
.
async function pageAsBlob(handle) {
let response = await chrome.documentScan.startScan(
handle, {format: "image/jpeg"});
if (response.result != chrome.documentScan.OperationResult.SUCCESS) {
return null;
}
const job = response.job;
let imgParts = [];
response = await chrome.documentScan.readScanData(job);
while (response.result == chrome.documentScan.OperationResult.SUCCESS) {
if (response.data && response.data.byteLength > 0) {
imgParts.push(response.data);
} else {
// Delay so hardware can make progress.
await new Promise(r => setTimeout(r, 100));
}
response = await chrome.documentScan.readScanData(job);
}
if (response.result != chrome.documentScan.OperationResult.EOF) {
return null;
}
if (response.data && response.data.byteLength > 0) {
imgParts.push(response.data);
}
return new Blob(imgParts, { type: "image/jpeg" });
}
Memindai satu halaman berukuran letter
Contoh ini menunjukkan cara memilih pemindai, menyetel opsinya, dan membukanya. Kemudian, aplikasi akan mengambil konten satu halaman dan menutup pemindai. Proses ini menunjukkan penggunaan getScannerList()
, openScanner()
, setOptions()
, dan closeScanner()
. Perhatikan bahwa konten halaman diambil dengan memanggil
fungsi pageAsBlob()
dari contoh sebelumnya.
async function scan() {
let response = await chrome.documentScan.getScannerList({ secure: true });
let scanner = await chrome.documentScan.openScanner(
response.scanners[0].scannerId);
const handle = scanner.scannerHandle;
let options = [];
for (source of scanner.options["source"].constraint.list) {
if (source.includes("ADF")) {
options.push({
name: "source",
type: chrome.documentScan.OptionType.STRING,
value: { value: source }
});
break;
}
}
options.push({
name: "tl-x",
type: chrome.documentScan.OptionType.FIXED,
value: 0.0
});
options.push({
name: "br-x",
type: chrome.documentScan.OptionType.FIXED,
value: 215.9 // 8.5" in mm
});
options.push({
name: "tl-y",
type: chrome.documentScan.OptionType.FIXED,
value: 0.0
});
options.push({
name: "br-y",
type: chrome.documentScan.OptionType.FIXED,
value: 279.4 // 11" in mm
});
response = await chrome.documentScan.setOptions(handle, options);
let imgBlob = await pageAsBlob(handle);
if (imgBlob != null) {
// Insert imgBlob into DOM, save to disk, etc
}
await chrome.documentScan.closeScanner(handle);
}
Tampilkan konfigurasi
Seperti yang dinyatakan di tempat lain, menampilkan opsi konfigurasi pemindai kepada pengguna memerlukan
panggilan getOptionGroups()
selain opsi pemindai yang ditampilkan dari
panggilan ke openScanner()
. Hal ini agar opsi dapat ditampilkan kepada pengguna dalam grup yang ditentukan produsen. Contoh ini menunjukkan cara melakukannya.
async function showConfig() {
let response = await chrome.documentScan.getScannerList({ secure: true });
let scanner = await chrome.documentScan.openScanner(
response.scanners[0].scannerId);
let groups = await chrome.documentScan.getOptionGroups(scanner.scannerHandle);
for (const group of groups.groups) {
console.log("=== " + group.title + " ===");
for (const member of group.members) {
const option = scanner.options[member];
if (option.isActive) {
console.log(" " + option.name + " = " + option.value);
} else {
console.log(" " + option.name + " is inactive");
}
}
}
}
Jenis
CancelScanResponse
Properti
-
tugas
string
Memberikan handle tugas yang sama dengan yang diteruskan ke
cancelScan()
. -
hasil
Hasil pembatalan pemindaian backend. Jika hasilnya adalah
OperationResult.SUCCESS
atauOperationResult.CANCELLED
, pemindaian telah dibatalkan dan pemindai siap memulai pemindaian baru. Jika hasilnya adalahOperationResult.DEVICE_BUSY
, pemindai masih memproses pembatalan yang diminta; pemanggil harus menunggu sebentar dan mencoba permintaan lagi. Nilai hasil lainnya menunjukkan error permanen yang tidak boleh dicoba lagi.
CloseScannerResponse
Properti
-
hasil
Hasil penutupan pemindai. Meskipun nilai ini bukan
SUCCESS
, handle akan menjadi tidak valid dan tidak boleh digunakan untuk operasi lebih lanjut. -
scannerHandle
string
Handle pemindai yang sama seperti yang diteruskan ke
closeScanner
.
Configurability
Cara mengubah opsi.
Enum
"NOT_CONFIGURABLE"
Opsi bersifat hanya baca.
"SOFTWARE_CONFIGURABLE"
Opsi dapat ditetapkan di software.
"HARDWARE_CONFIGURABLE"
Opsi dapat ditetapkan oleh pengguna dengan mengalihkan atau menekan tombol pada pemindai.
ConnectionType
Menunjukkan cara pemindai terhubung ke komputer.
Enum
"UNSPECIFIED"
"USB"
"NETWORK"
Enum
"INT_RANGE"
Batasan pada rentang nilai OptionType.INT
. Properti min
, max
, dan quant
dari OptionConstraint
akan menjadi long
, dan properti list
-nya akan dibatalkan.
"FIXED_RANGE"
Batasan pada rentang nilai OptionType.FIXED
. Properti min
, max
, dan quant
dari OptionConstraint
akan menjadi double
, dan properti list
-nya akan dibatalkan.
"INT_LIST"
Batasan pada daftar nilai OptionType.INT
tertentu. Properti OptionConstraint.list
akan berisi nilai long
, dan properti lainnya tidak akan ditetapkan.
"FIXED_LIST"
Batasan pada daftar nilai OptionType.FIXED
tertentu. Properti OptionConstraint.list
akan berisi nilai double
, dan properti lainnya tidak akan ditetapkan.
"STRING_LIST"
Batasan pada daftar nilai OptionType.STRING
tertentu. Properti OptionConstraint.list
akan berisi nilai DOMString
, dan properti lainnya tidak akan ditetapkan.
DeviceFilter
Properti
-
lokal
boolean opsional
Hanya menampilkan pemindai yang terhubung langsung ke komputer.
-
aman
boolean opsional
Hanya menampilkan pemindai yang menggunakan transportasi aman, seperti USB atau TLS.
GetOptionGroupsResponse
Properti
-
yang dilacak
OptionGroup[] opsional
Jika
result
adalahSUCCESS
, akan memberikan daftar grup opsi dalam urutan yang diberikan oleh driver pemindai. -
hasil
Hasil mendapatkan grup opsi. Jika nilainya adalah
SUCCESS
, propertigroups
akan diisi. -
scannerHandle
string
Handle pemindai yang sama seperti yang diteruskan ke
getOptionGroups
.
GetScannerListResponse
Properti
-
hasil
Hasil enumerasi. Perhatikan bahwa hasil parsial dapat ditampilkan meskipun hal ini menunjukkan error.
-
pemindai
Daftar pemindai yang mungkin kosong yang cocok dengan
DeviceFilter
yang diberikan.
OpenScannerResponse
Properti
-
opsi
objek opsional
Jika
result
adalahSUCCESS
, memberikan pemetaan nilai kunci dengan kunci berupa opsi khusus perangkat dan nilai berupa instanceScannerOption
. -
hasil
Hasil pembukaan pemindai. Jika nilainya adalah
SUCCESS
, propertiscannerHandle
danoptions
akan diisi. -
scannerHandle
string opsional
Jika
result
adalahSUCCESS
, maka akan ada handle ke pemindai yang dapat digunakan untuk operasi lebih lanjut. -
scannerId
string
ID pemindai yang diteruskan ke
openScanner()
.
OperationResult
Enum yang menunjukkan hasil setiap operasi.
Enum
"UNKNOWN"
Terjadi kegagalan yang tidak diketahui atau umum.
"SUCCESS"
Operasi berhasil.
"UNSUPPORTED"
Operasi tidak didukung.
"DIBATALKAN"
Operasi dibatalkan.
"DEVICE_BUSY"
Perangkat sedang sibuk.
"TIDAK VALID"
Data atau argumen yang diteruskan ke metode tidak valid.
"WRONG_TYPE"
Nilai yang diberikan adalah jenis data yang salah untuk opsi yang mendasarinya.
"EOF"
Tidak ada lagi data yang tersedia.
"ADF_JAMMED"
Pengumpan dokumen macet.
"ADF_EMPTY"
Pengumpan dokumen kosong.
"COVER_OPEN"
Penutup flatbed terbuka.
"IO_ERROR"
Terjadi error saat berkomunikasi dengan perangkat.
"ACCESS_DENIED"
Perangkat memerlukan autentikasi.
"NO_MEMORY"
Memori yang tersedia di Chromebook tidak cukup untuk menyelesaikan operasi.
"TIDAK DAPAT DIJANGKAU"
Perangkat tidak dapat dijangkau.
"TIDAK ADA"
Koneksi perangkat terputus.
"INTERNAL_ERROR"
Terjadi error di tempat lain selain di aplikasi yang memanggil.
OptionConstraint
Properti
-
list
string[] | number[] opsional
-
maks
nomor opsional
-
mnt
nomor opsional
-
quant
nomor opsional
-
jenis
OptionGroup
Properti
-
anggota
string[]
Array nama opsi dalam urutan yang disediakan driver.
-
judul
string
Memberikan judul yang dapat dicetak, misalnya "Opsi geometri".
OptionSetting
Properti
-
nama
string
Menunjukkan nama opsi yang akan disetel.
-
jenis
Menunjukkan jenis data opsi. Jenis data yang diminta harus cocok dengan jenis data sebenarnya dari opsi pokok.
-
nilai
string | number | boolean | number[] opsional
Menunjukkan nilai yang akan ditetapkan. Biarkan tidak disetel untuk meminta setelan otomatis untuk opsi yang mengaktifkan
autoSettable
. Jenis data yang diberikan untukvalue
harus cocok dengantype
.
OptionType
Jenis data opsi.
Enum
"UNKNOWN"
Jenis data opsi tidak diketahui. Properti value
akan dibatalkan.
"BOOL"
Properti value
akan menjadi salah satu dari true
false.
"INT"
Bilangan bulat 32-bit bertanda. Properti value
akan berupa long atau long[], bergantung pada apakah opsi mengambil lebih dari satu nilai.
"TETAP"
Double dalam rentang -32768-32767.9999 dengan resolusi 1/65535. Properti value
akan berupa double atau double[], bergantung pada apakah opsi mengambil lebih dari satu nilai. Nilai ganda yang tidak dapat direpresentasikan secara persis akan dibulatkan ke rentang dan presisi yang tersedia.
"STRING"
Urutan byte apa pun kecuali NUL ('\0'). Properti value
akan berupa DOMString.
"BUTTON"
Opsi jenis ini tidak memiliki nilai. Sebaliknya, menyetel opsi jenis ini akan menyebabkan efek samping khusus opsi di driver pemindai. Misalnya, opsi berjenis tombol dapat digunakan oleh driver pemindai untuk menyediakan cara memilih nilai default atau untuk memberi tahu pengumpan dokumen otomatis agar beralih ke lembar kertas berikutnya.
"GROUP"
Opsi pengelompokan. Tidak ada nilai. Ini disertakan untuk kompatibilitas, tetapi biasanya tidak akan ditampilkan dalam nilai ScannerOption
. Gunakan getOptionGroups()
untuk mengambil daftar grup beserta opsi anggotanya.
Enum
"TANPA SATUAN"
Nilainya adalah angka tanpa satuan. Misalnya, ini bisa berupa nilai minimum.
"PIXEL"
Nilainya adalah jumlah piksel, misalnya, dimensi pemindaian.
"BIT"
Nilainya adalah jumlah bit, misalnya, kedalaman warna.
"MM"
Nilai diukur dalam milimeter, misalnya, dimensi pemindaian.
"DPI"
Nilai diukur dalam titik per inci, misalnya, resolusi.
"PERCENT"
Nilainya adalah persentase, misalnya, kecerahan.
"MICROSECOND"
Nilai diukur dalam mikrodetik, misalnya, waktu eksposur.
ReadScanDataResponse
Properti
-
data
ArrayBuffer opsional
Jika
result
adalahSUCCESS
, berisi potongan berikutnya dari data gambar yang dipindai. Jikaresult
adalahEOF
, berisi potongan terakhir data gambar yang dipindai. -
estimatedCompletion
nomor opsional
Jika
result
adalahSUCCESS
, perkiraan jumlah total data pemindaian yang telah dikirimkan sejauh ini, dalam rentang 0 hingga 100. -
tugas
string
Menyediakan handle tugas yang diteruskan ke
readScanData()
. -
hasil
Hasil membaca data. Jika nilainya adalah
SUCCESS
, makadata
berisi potongan data gambar berikutnya (mungkin panjangnya nol) yang siap dibaca. Jika nilainya adalahEOF
,data
berisi potongan data gambar terakhir.
ScannerInfo
Properti
-
connectionType
Menunjukkan cara pemindai terhubung ke komputer.
-
deviceUuid
string
Untuk mencocokkan dengan entri
ScannerInfo
lain yang mengarah ke perangkat fisik yang sama. -
imageFormats
string[]
Array jenis MIME yang dapat diminta untuk hasil pemindaian yang ditampilkan.
-
produsen
string
Produsen pemindai.
-
model
string
Model pemindai jika tersedia, atau deskripsi umum.
-
nama
string
Nama yang dapat dibaca manusia untuk pemindai yang akan ditampilkan di UI.
-
protocolType
string
Deskripsi protokol atau driver yang dapat dibaca manusia yang digunakan untuk mengakses pemindai, seperti Mopria, WSD, atau epsonscan. Hal ini terutama berguna untuk memungkinkan pengguna memilih antara protokol jika perangkat mendukung beberapa protokol.
-
scannerId
string
ID pemindai tertentu.
-
aman
boolean
Jika benar (true), transport koneksi pemindai tidak dapat dicegat oleh pendengar pasif, seperti TLS atau USB.
ScannerOption
Properti
-
dapat dikonfigurasi
Menunjukkan apakah dan bagaimana opsi dapat diubah.
-
batasan
OptionConstraint opsional
Menentukan
OptionConstraint
pada opsi pemindai saat ini. -
deskripsi
string
Deskripsi opsi yang lebih panjang.
-
isActive
boolean
Menunjukkan bahwa opsi aktif dan dapat disetel atau diambil. Jika salah (false), properti
value
tidak akan ditetapkan. -
isAdvanced
boolean
Menunjukkan bahwa UI tidak boleh menampilkan opsi ini secara default.
-
isAutoSettable
boolean
Dapat disetel secara otomatis oleh driver pemindai.
-
isDetectable
boolean
Menunjukkan bahwa opsi ini dapat dideteksi dari software.
-
isEmulated
boolean
Diemulasi oleh driver pemindai jika benar.
-
nama
string
Nama opsi menggunakan huruf ASCII kecil, angka, dan tanda hubung. Diakritik tidak diizinkan.
-
judul
string
Judul satu baris yang dapat dicetak.
-
jenis
Jenis data yang ada dalam properti
value
, yang diperlukan untuk menetapkan opsi ini. -
satuan
Satuan ukur untuk opsi ini.
-
nilai
string | number | boolean | number[] opsional
Nilai opsi saat ini, jika relevan. Perhatikan bahwa jenis data properti ini harus cocok dengan jenis data yang ditentukan dalam
type
.
ScanOptions
Properti
-
maxImages
nomor opsional
Jumlah gambar yang dipindai yang diizinkan. Nilai defaultnya adalah 1.
-
mimeTypes
string[] opsional
Jenis MIME yang diterima oleh pemanggil.
ScanResults
Properti
-
dataUrls
string[]
Array URL gambar data dalam bentuk yang dapat diteruskan sebagai nilai "src" ke tag gambar.
-
mimeType
string
Jenis MIME
dataUrls
.
SetOptionResult
Properti
-
nama
string
Menunjukkan nama opsi yang ditetapkan.
-
hasil
Menunjukkan hasil penyetelan opsi.
SetOptionsResponse
Properti
-
opsi
objek opsional
Pemetaan key-value yang diperbarui dari nama opsi ke nilai
ScannerOption
yang berisi konfigurasi baru setelah mencoba menyetel semua opsi yang diberikan. Strukturnya sama dengan propertioptions
diOpenScannerResponse
.Properti ini akan disetel meskipun beberapa opsi tidak berhasil disetel, tetapi akan dibatalkan jika pengambilan konfigurasi yang diperbarui gagal (misalnya, jika pemindai terputus di tengah pemindaian).
-
hasil
Array hasil, masing-masing satu untuk setiap
OptionSetting
yang diteruskan. -
scannerHandle
string
Menyediakan handle pemindai yang diteruskan ke
setOptions()
.
StartScanOptions
Properti
-
format
string
Menentukan jenis MIME untuk menampilkan data yang dipindai.
-
maxReadSize
nomor opsional
Jika nilai bukan nol ditentukan, batasi byte yang dipindai maksimum yang ditampilkan dalam satu respons
readScanData
ke nilai tersebut. Nilai terkecil yang diizinkan adalah 32768 (32 KB). Jika properti ini tidak ditentukan, ukuran potongan yang ditampilkan dapat sebesar seluruh gambar yang dipindai.
StartScanResponse
Properti
-
tugas
string opsional
Jika
result
adalahSUCCESS
, akan menyediakan handle yang dapat digunakan untuk membaca data pemindaian atau membatalkan tugas. -
hasil
Hasil memulai pemindaian. Jika nilainya adalah
SUCCESS
, propertijob
akan diisi. -
scannerHandle
string
Memberikan handle pemindai yang sama yang diteruskan ke
startScan()
.
Metode
cancelScan()
chrome.documentScan.cancelScan(
job: string,
): Promise<CancelScanResponse>
Membatalkan pemindaian yang dimulai dan menampilkan Promise yang diselesaikan dengan objek CancelScanResponse
. Jika callback digunakan, objek akan diteruskan ke callback tersebut.
Parameter
-
tugas
string
Handle tugas pemindaian aktif yang sebelumnya ditampilkan dari panggilan ke
startScan
.
Hasil
-
Promise<CancelScanResponse>
closeScanner()
chrome.documentScan.closeScanner(
scannerHandle: string,
): Promise<CloseScannerResponse>
Menutup pemindai dengan handle yang diteruskan dan menampilkan Promise yang diselesaikan dengan objek CloseScannerResponse
. Jika callback digunakan, objek akan diteruskan ke callback tersebut. Meskipun respons tidak berhasil, handle yang diberikan menjadi tidak valid dan tidak boleh digunakan untuk operasi lebih lanjut.
Parameter
-
scannerHandle
string
Menentukan handle pemindai terbuka yang sebelumnya ditampilkan dari panggilan ke
openScanner
.
Hasil
-
Promise<CloseScannerResponse>
getOptionGroups()
chrome.documentScan.getOptionGroups(
scannerHandle: string,
): Promise<GetOptionGroupsResponse>
Mendapatkan nama grup dan opsi anggota dari pemindai yang sebelumnya dibuka oleh openScanner
. Metode ini menampilkan Promise yang diselesaikan dengan objek GetOptionGroupsResponse
. Jika callback diteruskan ke fungsi ini, data yang ditampilkan akan diteruskan ke callback tersebut.
Parameter
-
scannerHandle
string
Tuas pemindai terbuka yang ditampilkan dari panggilan ke
openScanner
.
Hasil
-
Promise<GetOptionGroupsResponse>
getScannerList()
chrome.documentScan.getScannerList(
filter: DeviceFilter,
): Promise<GetScannerListResponse>
Mendapatkan daftar pemindai yang tersedia dan menampilkan Promise yang diselesaikan dengan objek GetScannerListResponse
. Jika callback diteruskan ke fungsi ini, data yang ditampilkan akan diteruskan ke callback tersebut.
Parameter
-
filter
DeviceFilter
yang menunjukkan jenis pemindai yang harus ditampilkan.
Hasil
-
Promise<GetScannerListResponse>
openScanner()
chrome.documentScan.openScanner(
scannerId: string,
): Promise<OpenScannerResponse>
Membuka pemindai untuk akses eksklusif dan menampilkan Promise yang diselesaikan dengan objek OpenScannerResponse
. Jika callback diteruskan ke fungsi ini, data yang ditampilkan akan diteruskan ke callback tersebut.
Parameter
-
scannerId
string
ID pemindai yang akan dibuka. Nilai ini adalah salah satu yang ditampilkan dari panggilan sebelumnya ke
getScannerList
.
Hasil
-
Promise<OpenScannerResponse>
readScanData()
chrome.documentScan.readScanData(
job: string,
): Promise<ReadScanDataResponse>
Membaca potongan data gambar berikutnya yang tersedia dari handle tugas aktif, dan menampilkan Promise yang di-resolve dengan objek ReadScanDataResponse
. Jika callback digunakan, objek akan diteruskan ke callback tersebut.
**Catatan:**Hasil respons yang berupa SUCCESS
dengan anggota data
yang panjangnya nol adalah valid. Artinya, pemindai masih berfungsi, tetapi belum siap untuk menerima data tambahan. Penelepon harus menunggu sebentar dan mencoba lagi.
Setelah tugas pemindaian selesai, respons akan memiliki nilai hasil EOF
. Respons ini mungkin berisi anggota data
akhir yang bukan nol.
Parameter
-
tugas
string
Handle tugas aktif yang sebelumnya ditampilkan dari
startScan
.
Hasil
-
Promise<ReadScanDataResponse>
scan()
chrome.documentScan.scan(
options: ScanOptions,
): Promise<ScanResults>
Melakukan pemindaian dokumen dan menampilkan Promise yang di-resolve dengan objek ScanResults
. Jika callback diteruskan ke fungsi ini, data yang ditampilkan akan diteruskan ke callback tersebut.
Parameter
-
opsi
Objek yang berisi parameter pemindaian.
Hasil
-
Promise<ScanResults>
Chrome 96+
setOptions()
chrome.documentScan.setOptions(
scannerHandle: string,
options: OptionSetting[],
): Promise<SetOptionsResponse>
Menetapkan opsi pada pemindai yang ditentukan dan menampilkan Promise yang diselesaikan dengan objek SetOptionsResponse
yang berisi hasil upaya untuk menetapkan setiap nilai dalam urutan objek OptionSetting
yang diteruskan. Jika callback digunakan, objek akan diteruskan ke callback tersebut.
Parameter
-
scannerHandle
string
Handle pemindai untuk menyetel opsi. Nilai ini harus berupa nilai yang sebelumnya ditampilkan dari panggilan ke
openScanner
. -
opsi
Daftar objek
OptionSetting
yang akan diterapkan ke pemindai.
Hasil
-
Promise<SetOptionsResponse>
startScan()
chrome.documentScan.startScan(
scannerHandle: string,
options: StartScanOptions,
): Promise<StartScanResponse>
Memulai pemindaian pada pemindai yang ditentukan dan menampilkan Promise yang diselesaikan dengan StartScanResponse
. Jika callback digunakan, objek akan diteruskan ke callback tersebut. Jika panggilan berhasil, respons akan menyertakan handle tugas yang dapat digunakan dalam panggilan berikutnya untuk membaca data pemindaian atau membatalkan pemindaian.
Parameter
-
scannerHandle
string
Gagang pemindai yang terbuka. Nilai ini harus berupa nilai yang sebelumnya ditampilkan dari panggilan ke
openScanner
. -
opsi
Objek
StartScanOptions
yang menunjukkan opsi yang akan digunakan untuk pemindaian. PropertiStartScanOptions.format
harus cocok dengan salah satu entri yang ditampilkan diScannerInfo
pemindai.
Hasil
-
Promise<StartScanResponse>