Descripción
Usa la API de chrome.documentScan
para descubrir y recuperar imágenes de los escáneres de documentos adjuntos.
La API de Document Scan está diseñada para permitir que las apps y extensiones vean el contenido de documentos en papel en un escáner de documentos adjunto.
Permisos
documentScan
Disponibilidad
Conceptos y uso
Esta API admite dos formas de escanear documentos. Si tu caso de uso puede funcionar con cualquier escáner y no requiere el control de la configuración, usa el método scan()
. Los casos de uso más complicados requieren una combinación de métodos, que solo son compatibles con Chrome 124 y versiones posteriores.
Análisis simple
Para casos de uso simples, es decir, aquellos que pueden funcionar con cualquier escáner y no requieren control de la configuración, llama a scan()
. Este método toma un objeto ScanOptions
y devuelve una promesa que se resuelve con un objeto ScanResults
. Las capacidades de esta opción se limitan a la cantidad de análisis y los tipos de MIME que aceptará la persona que llama. Los análisis se muestran como URLs para su visualización en una etiqueta <img>
para una interfaz de usuario.
Análisis complejo
Los análisis complejos se realizan en tres fases, como se describe en esta sección. En este esquema, no se describen todos los argumentos del método ni todas las propiedades que se devuelven en una respuesta. Solo tiene el objetivo de brindarte una guía general para escribir código de escáner.
Discovery
Llama a
getScannerList()
. Los escáneres disponibles se devuelven en una promesa que se resuelve con unGetScannerListResponse
.- El objeto de respuesta contiene un array de objetos
ScannerInfo
. - El array puede contener varias entradas para un solo escáner si este admite varios protocolos o métodos de conexión.
- El objeto de respuesta contiene un array de objetos
Selecciona un escáner del array que se devolvió y guarda el valor de su propiedad
scannerId
.Usa las propiedades de los objetos
ScannerInfo
individuales para distinguir entre varios objetos del mismo escáner. Los objetos del mismo escáner tendrán el mismo valor para la propiedaddeviceUuid
.ScannerInfo
también contiene una propiedadimageFormats
que incluye un array de tipos de imágenes admitidos.
Configuración del escáner
Llama a
openScanner()
y pasa el ID del escáner guardado. Devuelve una promesa que se resuelve con unOpenScannerResponse
. El objeto de respuesta contiene lo siguiente:Una propiedad
scannerHandle
, que deberás guardar.Es una propiedad de opciones que contiene propiedades específicas del escáner, que deberás configurar. Consulta Recupera opciones del escáner para obtener más información.
(Opcional) Si necesitas que el usuario proporcione valores para las opciones del escáner, crea una interfaz de usuario. Necesitarás las opciones del escáner que se proporcionaron en el paso anterior y deberás recuperar los grupos de opciones que proporciona el escáner. Consulta Cómo construir una interfaz de usuario para obtener más información.
Construye un array de objetos
OptionSetting
con valores proporcionados por el usuario o de forma programática. Consulta Configura las opciones del escáner para obtener más información.Pasa el array de objetos
OptionSetting
asetOptions()
para establecer opciones para el escáner. Devuelve una promesa que se resuelve con unSetOptionsResponse
. Este objeto contiene una versión actualizada de las opciones del escáner recuperadas en el paso 1 de la configuración del escáner.Dado que cambiar una opción puede alterar las restricciones de otra, es posible que debas repetir estos pasos varias veces.
Análisis
Construye un objeto
StartScanOptions
y pásalo astartScan()
. Devuelve una promesa que se resuelve con unStartScanResponse
. Su propiedadjob
es un identificador que usarás para leer los datos del análisis o cancelarlo.Pasa el identificador del trabajo a
readScanData()
. Devuelve una promesa que se resuelve con un objetoReadScanDataResponse
. Si los datos se leyeron correctamente, su propiedadresult
será igual aSUCCESS
y su propiedaddata
contendrá unArrayBuffer
con parte del análisis. Ten en cuenta queestimatedCompletion
contiene un porcentaje estimado de los datos totales que se entregaron hasta el momento.Repite el paso anterior hasta que la propiedad
result
sea igual aEOF
o se produzca un error.
Cuando se llegue al final del análisis, llama a closeScanner()
con el identificador del escáner guardado en el paso 3. Devuelve una promesa que se resuelve con un CloseScannerResponse
. Llamar a cancelScan()
en cualquier momento después de que se cree el trabajo finalizará el análisis.
Objetos de respuesta
Todos los métodos devuelven una promesa que se resuelve con un objeto de respuesta de algún tipo.
La mayoría de estos contienen una propiedad result
cuyo valor es un miembro de OperationResult
. Algunas propiedades de los objetos de respuesta no contendrán valores, a menos que el valor de result
tenga un valor específico. Estas relaciones se describen en la referencia de cada objeto de respuesta.
Por ejemplo, OpenScannerResponse.scannerHandle
solo tendrá un valor cuando OpenScannerResponse.result
sea igual a SUCCESS
.
Opciones del escáner
Las opciones del escáner varían considerablemente según el dispositivo. Por lo tanto, no es posible reflejar las opciones del escáner directamente en la API de documentScan. Para evitar este problema, OpenScannerResponse
(recuperado con openScanner()
) y SetOptionsResponse
(el objeto de respuesta para setOptions()
) contienen una propiedad options
que es un objeto que contiene opciones específicas del escáner. Cada opción es una asignación de clave-valor en la que la clave es una opción específica del dispositivo y el valor es una instancia de ScannerOption
.
Por lo general, la estructura se ve de la siguiente manera:
{
"key1": { scannerOptionInstance }
"key2": { scannerOptionInstance }
}
Por ejemplo, imagina un escáner que devuelve opciones llamadas "source" y "resolution". La estructura del objeto options
devuelto se verá similar al siguiente ejemplo. Para simplificar, solo se muestran respuestas ScannerOption
parciales.
{
"source": {
"name": "source",
"type": OptionType.STRING,
...
},
"resolution": {
"name": "resolution",
"type": OptionType.INT,
...
},
...
}
Cómo construir una interfaz de usuario
Si bien no es obligatorio usar esta API, es posible que desees que el usuario elija el valor de una opción en particular. Esto requiere una interfaz de usuario. Usa OpenScannerResponse
(que se abre con openScanner()
) para recuperar las opciones del escáner adjunto, como se describe en la sección anterior.
Algunos escáneres agrupan las opciones de formas específicas para cada dispositivo. No afectan el comportamiento de las opciones, pero, como es posible que se mencionen en la documentación del producto de un escáner, se deben mostrar al usuario. Puedes recuperar estos grupos llamando a getOptionGroups()
. Esto devuelve una promesa que se resuelve con un objeto GetOptionGroupsResponse
. Su propiedad groups
contiene un array de grupos específico del escáner. Usa la información de estos grupos para organizar las opciones en OpenScannerResponse
para su visualización.
{
scannerHandle: "123456",
result: SUCCESS,
groups: [
{
title: "Standard",
members: [ "resolution", "mode", "source" ]
}
]
}
Como se indica en Configuración del escáner, cambiar una opción puede alterar las restricciones de otra. Por eso, setOptionsResponse
(el objeto de respuesta para setOptions()
) contiene otra propiedad options
. Úsalo para actualizar la interfaz de usuario. Luego, repite el proceso según sea necesario hasta que se establezcan todas las opciones.
Cómo configurar las opciones del escáner
Para configurar las opciones del escáner, pasa un array de objetos OptionSetting
a setOptions()
. Para ver un ejemplo, consulta la siguiente sección Cómo escanear una página de tamaño carta.
Ejemplos
Cómo recuperar una página como un BLOB
En este ejemplo, se muestra una forma de recuperar una página del escáner como un blob y se demuestra el uso de startScan()
y readScanData()
con el valor de 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" });
}
Escanear una página de tamaño carta
En este ejemplo, se muestra cómo seleccionar un escáner, establecer sus opciones y abrirlo. Luego, recupera el contenido de una sola página y cierra el escáner. En este proceso, se muestra cómo usar getScannerList()
, openScanner()
, setOptions()
y closeScanner()
. Ten en cuenta que el contenido de la página se recupera llamando a la función pageAsBlob()
del ejemplo anterior.
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);
}
Cómo mostrar la configuración
Como se indicó en otra parte, mostrar las opciones de configuración de un escáner a un usuario requiere llamar a getOptionGroups()
, además de las opciones del escáner que se devuelven desde una llamada a openScanner()
. Esto permite que se muestren opciones a los usuarios en grupos definidos por el fabricante. En este ejemplo, se muestra cómo hacerlo.
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");
}
}
}
}
Tipos
CancelScanResponse
Propiedades
-
trabajo
string
Proporciona el mismo identificador de trabajo que se pasó a
cancelScan()
. -
resultado
Es el resultado de la cancelación del análisis del backend. Si el resultado es
OperationResult.SUCCESS
oOperationResult.CANCELLED
, se canceló el análisis y el escáner está listo para iniciar uno nuevo. Si el resultado esOperationResult.DEVICE_BUSY
, el escáner aún está procesando la cancelación solicitada. El llamador debe esperar un poco y volver a intentar la solicitud. Otros valores de resultado indican un error permanente que no se debe volver a intentar.
CloseScannerResponse
Propiedades
-
resultado
Es el resultado de cerrar el escáner. Incluso si este valor no es
SUCCESS
, el identificador no será válido y no se debe usar para ninguna otra operación. -
scannerHandle
string
Es el mismo identificador del escáner que se pasó a
closeScanner
.
Configurability
Cómo se puede cambiar una opción.
Enum
"NOT_CONFIGURABLE"
La opción es de solo lectura.
"SOFTWARE_CONFIGURABLE"
La opción se puede configurar en el software.
"HARDWARE_CONFIGURABLE"
El usuario puede establecer la opción activando o presionando un botón en el escáner.
ConnectionType
Indica cómo está conectado el escáner a la computadora.
Enum
"UNSPECIFIED"
"USB"
"NETWORK"
ConstraintType
Es el tipo de datos de la restricción representada por un OptionConstraint
.
Enum
"INT_RANGE"
Es la restricción sobre un rango de valores de OptionType.INT
. Las propiedades min
, max
y quant
de OptionConstraint
serán long
, y su propiedad list
no se establecerá.
"FIXED_RANGE"
Es la restricción sobre un rango de valores de OptionType.FIXED
. Las propiedades min
, max
y quant
de OptionConstraint
serán double
, y su propiedad list
no se establecerá.
"INT_LIST"
Es la restricción sobre una lista específica de valores de OptionType.INT
. La propiedad OptionConstraint.list
contendrá valores de long
y las demás propiedades no se establecerán.
"FIXED_LIST"
Es la restricción sobre una lista específica de valores de OptionType.FIXED
. La propiedad OptionConstraint.list
contendrá valores de double
y las demás propiedades no se establecerán.
"STRING_LIST"
Es la restricción sobre una lista específica de valores de OptionType.STRING
. La propiedad OptionConstraint.list
contendrá valores de DOMString
y las demás propiedades no se establecerán.
DeviceFilter
Propiedades
-
local
booleano opcional
Solo se devuelven los escáneres que están conectados directamente a la computadora.
-
seguro
booleano opcional
Solo se devuelven los escáneres que usan un transporte seguro, como USB o TLS.
GetOptionGroupsResponse
Propiedades
-
grupos
OptionGroup[] opcional
Si
result
esSUCCESS
, proporciona una lista de grupos de opciones en el orden que proporciona el controlador del escáner. -
resultado
Es el resultado de obtener los grupos de opciones. Si el valor es
SUCCESS
, se propagará la propiedadgroups
. -
scannerHandle
string
Es el mismo identificador del escáner que se pasó a
getOptionGroups
.
GetScannerListResponse
Propiedades
-
resultado
Es el resultado de la enumeración. Ten en cuenta que se podrían devolver resultados parciales incluso si esto indica un error.
-
escáneres
Es una lista, posiblemente vacía, de los analizadores que coinciden con el
DeviceFilter
proporcionado.
OpenScannerResponse
Propiedades
-
opciones
objeto opcional
Si
result
esSUCCESS
, proporciona una asignación de clave-valor en la que la clave es una opción específica del dispositivo y el valor es una instancia deScannerOption
. -
resultado
Es el resultado de abrir el escáner. Si el valor es
SUCCESS
, se propagarán las propiedadesscannerHandle
yoptions
. -
scannerHandle
cadena opcional
Si
result
esSUCCESS
, es un identificador del escáner que se puede usar para otras operaciones. -
scannerId
string
Es el ID del escáner que se pasó a
openScanner()
.
OperationResult
Es una enumeración que indica el resultado de cada operación.
Enum
"UNKNOWN"
Se produjo un error desconocido o genérico.
"SUCCESS"
La operación se completó correctamente.
"UNSUPPORTED"
No se admite la operación.
"CANCELLED"
Se canceló la operación.
"DEVICE_BUSY"
El dispositivo está ocupado.
"INVALID"
Los datos o un argumento que se pasó al método no son válidos.
"WRONG_TYPE"
El valor proporcionado tiene un tipo de datos incorrecto para la opción subyacente.
"EOF"
No hay más datos disponibles.
"ADF_JAMMED"
Se atascó el alimentador de documentos.
"ADF_EMPTY"
El alimentador de documentos está vacío.
"COVER_OPEN"
La cubierta de la plataforma está abierta.
"IO_ERROR"
Se produjo un error durante la comunicación con el dispositivo.
"ACCESS_DENIED"
El dispositivo requiere autenticación.
"NO_MEMORY"
No hay suficiente memoria disponible en la Chromebook para completar la operación.
"UNREACHABLE"
No se puede acceder al dispositivo.
"MISSING"
El dispositivo está desconectado.
"INTERNAL_ERROR"
Se produjo un error en algún lugar que no es la aplicación que realiza la llamada.
OptionConstraint
Propiedades
-
list
string[] | number[] opcional
-
máx.
número opcional
-
min
número opcional
-
quant
número opcional
-
tipo
OptionGroup
Propiedades
-
miembros
string[]
Es un array de nombres de opciones en el orden proporcionado por el conductor.
-
título
string
Proporciona un título imprimible, por ejemplo, "Opciones de geometría".
OptionSetting
Propiedades
-
nombre
string
Indica el nombre de la opción que se configurará.
-
tipo
Indica el tipo de datos de la opción. El tipo de datos solicitado debe coincidir con el tipo de datos real de la opción subyacente.
-
valor
cadena | número | booleano | número[] opcional
Indica el valor que se establecerá. Déjalo sin configurar para solicitar el ajuste automático de las opciones que tienen habilitado
autoSettable
. El tipo de datos proporcionado paravalue
debe coincidir contype
.
OptionType
Es el tipo de datos de una opción.
Enum
"UNKNOWN"
Se desconoce el tipo de datos de la opción. Se anulará la propiedad value
.
"BOOL"
La propiedad value
será una de true
false.
"INT"
Es un número entero de 32 bits con firma. La propiedad value
será long o long[], según si la opción toma más de un valor.
"FIXED"
Un valor doble en el rango de -32768 a 32767.9999 con una resolución de 1/65535. La propiedad value
será double o double[], según si la opción toma más de un valor. Los valores dobles que no se puedan representar con exactitud se redondearán al rango y la precisión disponibles.
"STRING"
Una secuencia de cualquier byte, excepto NUL ("\0"). La propiedad value
será un DOMString.
"BUTTON"
Una opción de este tipo no tiene valor. En cambio, establecer una opción de este tipo provoca un efecto secundario específico de la opción en el controlador del escáner. Por ejemplo, un controlador de escáner podría usar una opción de tipo botón para proporcionar un medio para seleccionar valores predeterminados o para indicarle a un alimentador automático de documentos que avance a la siguiente hoja de papel.
"GROUP"
Opción de agrupación. Sin valor. Se incluye por compatibilidad, pero normalmente no se devolverá en los valores de ScannerOption
. Usa getOptionGroups()
para recuperar la lista de grupos con sus opciones de miembros.
Enum
"UNITLESS"
El valor es un número sin unidades. Por ejemplo, puede ser un umbral.
"PIXEL"
El valor es una cantidad de píxeles, por ejemplo, las dimensiones de escaneo.
"BIT"
El valor es la cantidad de bits, por ejemplo, la profundidad de color.
"MM"
El valor se mide en milímetros, por ejemplo, las dimensiones de escaneo.
"DPI"
El valor se mide en puntos por pulgada, por ejemplo, la resolución.
"PERCENT"
El valor es un porcentaje, por ejemplo, el brillo.
"MICROSECOND"
El valor se mide en microsegundos, por ejemplo, el tiempo de exposición.
ReadScanDataResponse
Propiedades
-
datos
ArrayBuffer opcional
Si
result
esSUCCESS
, contiene el siguiente fragmento de datos de la imagen analizada. Siresult
esEOF
, contiene el último fragmento de datos de la imagen analizada. -
estimatedCompletion
número opcional
Si
result
esSUCCESS
, es una estimación de la cantidad de datos de análisis totales que se entregaron hasta el momento, en el rango de 0 a 100. -
trabajo
string
Proporciona el identificador de trabajo que se pasó a
readScanData()
. -
resultado
Es el resultado de la lectura de datos. Si su valor es
SUCCESS
,data
contiene el siguiente fragmento (posiblemente de longitud cero) de datos de imagen que está listo para leerse. Si su valor esEOF
, el campodata
contiene el fragmento final de los datos de la imagen.
ScannerInfo
Propiedades
-
connectionType
Indica cómo está conectado el escáner a la computadora.
-
deviceUuid
string
Se usa para la correlación con otras entradas de
ScannerInfo
que apuntan al mismo dispositivo físico. -
imageFormats
string[]
Es un array de tipos de MIME que se pueden solicitar para los análisis devueltos.
-
manufacturer
string
Es el fabricante del escáner.
-
modelo
string
Modelo del escáner, si está disponible, o una descripción genérica.
-
nombre
string
Es un nombre legible por humanos para que el verificador lo muestre en la IU.
-
protocolType
string
Es una descripción legible del protocolo o controlador que se usa para acceder al escáner, como Mopria, WSD o epsonds. Esto es útil principalmente para permitir que un usuario elija entre protocolos si un dispositivo admite varios protocolos.
-
scannerId
string
Es el ID de un escáner específico.
-
seguro
booleano
Si es verdadero, el transporte de la conexión del escáner no puede ser interceptado por un agente de escucha pasivo, como TLS o USB.
ScannerOption
Propiedades
-
configurabilidad
Indica si se puede cambiar la opción y cómo.
-
restricción
OptionConstraint opcional
Define
OptionConstraint
en la opción de escáner actual. -
descripción
string
Es una descripción más larga de la opción.
-
Está activo
booleano
Indica que la opción está activa y se puede establecer o recuperar. Si es falso, no se establecerá la propiedad
value
. -
isAdvanced
booleano
Indica que la IU no debe mostrar esta opción de forma predeterminada.
-
isAutoSettable
booleano
El controlador del escáner puede establecer este valor automáticamente.
-
isDetectable
booleano
Indica que esta opción se puede detectar desde el software.
-
isEmulated
booleano
El controlador del escáner lo emula si es verdadero.
-
nombre
string
Nombre de la opción que usa letras ASCII en minúscula, números y guiones. No se permiten signos diacríticos.
-
título
string
Es un título imprimible de una sola línea.
-
tipo
Es el tipo de datos que contiene la propiedad
value
, que se necesita para establecer esta opción. -
Unidad
Es la unidad de medida de esta opción.
-
valor
cadena | número | booleano | número[] opcional
Es el valor actual de la opción, si es pertinente. Ten en cuenta que el tipo de datos de esta propiedad debe coincidir con el tipo de datos especificado en
type
.
ScanOptions
Propiedades
-
maxImages
número opcional
Es la cantidad de imágenes escaneadas permitidas. El valor predeterminado es 1.
-
mimeTypes
string[] opcional
Son los tipos de MIME que acepta la persona que llama.
ScanResults
Propiedades
-
dataUrls
string[]
Es un array de URLs de imágenes de datos en un formato que se puede pasar como el valor "src" a una etiqueta de imagen.
-
mimeType
string
Es el tipo de MIME de
dataUrls
.
SetOptionResult
Propiedades
-
nombre
string
Indica el nombre de la opción que se configuró.
-
resultado
Indica el resultado de la configuración de la opción.
SetOptionsResponse
Propiedades
-
opciones
objeto opcional
Es una asignación actualizada de clave-valor de los nombres de las opciones a los valores de
ScannerOption
que contiene la nueva configuración después de intentar establecer todas las opciones proporcionadas. Tiene la misma estructura que la propiedadoptions
enOpenScannerResponse
.Esta propiedad se establecerá incluso si algunas opciones no se establecieron correctamente, pero se anulará si falla la recuperación de la configuración actualizada (por ejemplo, si el escáner se desconecta en medio del análisis).
-
resultados
Es un array de resultados, uno para cada
OptionSetting
que se pasó. -
scannerHandle
string
Proporciona el identificador del escáner que se pasó a
setOptions()
.
StartScanOptions
Propiedades
-
formato
string
Especifica el tipo de MIME en el que se devolverán los datos analizados.
-
maxReadSize
número opcional
Si se especifica un valor distinto de cero, se limita a ese valor la cantidad máxima de bytes analizados que se devuelven en una sola respuesta de
readScanData
. El valor más pequeño permitido es 32768 (32 KB). Si no se especifica esta propiedad, el tamaño de un fragmento devuelto puede ser tan grande como la imagen escaneada completa.
StartScanResponse
Propiedades
-
trabajo
cadena opcional
Si
result
esSUCCESS
, proporciona un identificador que se puede usar para leer los datos del análisis o cancelar el trabajo. -
resultado
Es el resultado de iniciar un análisis. Si el valor es
SUCCESS
, se propagará la propiedadjob
. -
scannerHandle
string
Proporciona el mismo identificador del escáner que se pasó a
startScan()
.
Métodos
cancelScan()
chrome.documentScan.cancelScan(
job: string,
): Promise<CancelScanResponse>
Cancela un análisis iniciado y devuelve una promesa que se resuelve con un objeto CancelScanResponse
. Si se usa una devolución de llamada, el objeto se pasa a ella.
Parámetros
-
trabajo
string
Es el identificador de un trabajo de análisis activo que se devolvió anteriormente desde una llamada a
startScan
.
Muestra
-
Promise<CancelScanResponse>
closeScanner()
chrome.documentScan.closeScanner(
scannerHandle: string,
): Promise<CloseScannerResponse>
Cierra el escáner con el identificador pasado y devuelve una promesa que se resuelve con un objeto CloseScannerResponse
. Si se usa una devolución de llamada, el objeto se pasa a ella. Incluso si la respuesta no es exitosa, el identificador proporcionado deja de ser válido y no se debe usar para operaciones posteriores.
Parámetros
-
scannerHandle
string
Especifica el identificador de un escáner abierto que se devolvió anteriormente desde una llamada a
openScanner
.
Muestra
-
Promise<CloseScannerResponse>
getOptionGroups()
chrome.documentScan.getOptionGroups(
scannerHandle: string,
): Promise<GetOptionGroupsResponse>
Obtiene los nombres de los grupos y las opciones de miembros de un escáner que openScanner
abrió anteriormente. Este método devuelve una promesa que se resuelve con un objeto GetOptionGroupsResponse
. Si se pasa una devolución de llamada a esta función, los datos devueltos se pasan a ella.
Parámetros
-
scannerHandle
string
Es el identificador de un escáner abierto que se devolvió de una llamada a
openScanner
.
Muestra
-
Promise<GetOptionGroupsResponse>
getScannerList()
chrome.documentScan.getScannerList(
filter: DeviceFilter,
): Promise<GetScannerListResponse>
Obtiene la lista de escáneres disponibles y devuelve una promesa que se resuelve con un objeto GetScannerListResponse
. Si se pasa una devolución de llamada a esta función, los datos devueltos se pasan a ella.
Parámetros
-
filtrar
Un
DeviceFilter
que indica qué tipos de analizadores se deben devolver.
Muestra
-
Promise<GetScannerListResponse>
openScanner()
chrome.documentScan.openScanner(
scannerId: string,
): Promise<OpenScannerResponse>
Abre un scanner para acceso exclusivo y devuelve una promesa que se resuelve con un objeto OpenScannerResponse
. Si se pasa una devolución de llamada a esta función, los datos devueltos se pasan a ella.
Parámetros
-
scannerId
string
ID de un escáner que se abrirá. Este valor es uno de los que se devolvió en una llamada anterior a
getScannerList
.
Muestra
-
Promise<OpenScannerResponse>
readScanData()
chrome.documentScan.readScanData(
job: string,
): Promise<ReadScanDataResponse>
Lee el siguiente fragmento de datos de imagen disponibles de un identificador de trabajo activo y devuelve una promesa que se resuelve con un objeto ReadScanDataResponse
. Si se usa una devolución de llamada, el objeto se pasa a ella.
**Nota:**Es válido que un resultado de respuesta sea SUCCESS
con un miembro data
de longitud cero. Esto significa que el escáner sigue funcionando, pero aún no tiene datos adicionales listos. La persona que llama debe esperar un momento y volver a intentarlo.
Cuando se complete el trabajo de análisis, la respuesta tendrá el valor de resultado EOF
. Esta respuesta puede contener un miembro data
final distinto de cero.
Parámetros
-
trabajo
string
Es el identificador de trabajo activo que
startScan
devolvió anteriormente.
Muestra
-
Promise<ReadScanDataResponse>
scan()
chrome.documentScan.scan(
options: ScanOptions,
): Promise<ScanResults>
Realiza un análisis de documentos y devuelve una promesa que se resuelve con un objeto ScanResults
. Si se pasa una devolución de llamada a esta función, los datos devueltos se pasan a ella.
Parámetros
-
opciones
Es un objeto que contiene parámetros de análisis.
Muestra
-
Promesa de ScanResults
Chrome 96 y versiones posteriores
setOptions()
chrome.documentScan.setOptions(
scannerHandle: string,
options: OptionSetting[],
): Promise<SetOptionsResponse>
Establece opciones en el escáner especificado y devuelve una promesa que se resuelve con un objeto SetOptionsResponse
que contiene el resultado del intento de establecer cada valor en el orden del objeto OptionSetting
pasado. Si se usa una devolución de llamada, el objeto se pasa a ella.
Parámetros
-
scannerHandle
string
Es el identificador del escáner en el que se establecerán las opciones. Debe ser un valor que se haya mostrado anteriormente en una llamada a
openScanner
. -
opciones
Es una lista de objetos
OptionSetting
que se aplicarán al escáner.
Muestra
-
Promise<SetOptionsResponse>
startScan()
chrome.documentScan.startScan(
scannerHandle: string,
options: StartScanOptions,
): Promise<StartScanResponse>
Inicia un análisis en el escáner especificado y devuelve una promesa que se resuelve con un StartScanResponse
. Si se usa una devolución de llamada, el objeto se pasa a ella. Si la llamada se realizó correctamente, la respuesta incluye un identificador de trabajo que se puede usar en llamadas posteriores para leer los datos del análisis o cancelar un análisis.
Parámetros
-
scannerHandle
string
Es el identificador de un escáner abierto. Debe ser un valor que se haya mostrado anteriormente en una llamada a
openScanner
. -
opciones
Objeto
StartScanOptions
que indica las opciones que se usarán para el análisis. La propiedadStartScanOptions.format
debe coincidir con una de las entradas que se muestran en elScannerInfo
del escáner.
Muestra
-
Promise<StartScanResponse>