Skip to content

Latest commit

 

History

History
135 lines (114 loc) · 3.09 KB

idl.md

File metadata and controls

135 lines (114 loc) · 3.09 KB

Web IDL for Handwriting Recognition API

Entry point

[SecureContext]
partial interface Navigator {
  [CallWith=ScriptState, RaisesException]
  Promise<HandwritingRecognizer>
      createHandwritingRecognizer(HandwritingModelConstraints constraints);

  // V2 feature query.
  [CallWith=ScriptState, RaisesException]
  Promise<HandwritingRecognizerQueryResult?>
      queryHandwritingRecognizer(HandwritingModelConstraints constraints);
};

dictionary HandwritingModelConstraints {
  required sequence<DOMString> languages;
};

enum HandwritingRecognitionType{
  "text", "email", "number", "per-character"
};

enum HandwritingInputType {
  "mouse", "stylus", "touch"
};

dictionary HandwritingRecognizerQueryResult {
  bool textAlternatives;
  bool textSegmentation;
  HandwritingHintsQueryResult hints;
};

dictionary HandwritingHintsQueryResult {
  sequence<HandwritingRecognitionType> recognitionType;
  sequence<HandwritingInputType> inputType;
  bool textContext;
  bool alternatives;
};

Recognizer

[SecureContext]
interface HandwritingRecognizer {
  [CallWith=ScriptState, RaisesException]
  HandwritingDrawing startDrawing(optional HandwritingHints hints = {});

  [RaisesException] void finish();
};

dictionary HandwritingHints {
  sequence<DOMString> graphemeSet = [];
  DOMString recognitionType = "text";
  DOMString inputType = "mouse";
  DOMString textContext = "";
  unsigned long alternatives = 3;
};

Point and Stroke

[SecureContext, Exposed=Window]
interface HandwritingStroke {
  constructor();
  void addPoint(HandwritingPoint point);
  sequence<HandwritingPoint> getPoints();
  void clear();
};

dictionary HandwritingPoint {
  double x;
  double y;

  // The amount of time since the start of the current drawing.
  DOMHighResTimestamp t;
};

Drawing

[SecureContext]
interface HandwritingDrawing {
  void addStroke(HandwritingStroke stroke);
  void removeStroke(HandwritingStroke stroke);
  void clear();
  sequence<HandwritingStroke> getStrokes();

  [CallWith=ScriptState]
  Promise<sequence<HandwritingPrediction>> getPrediction();
};

dictionary HandwritingPrediction {
  required DOMString text;
  sequence<HandwritingSegment> segmentationResult;
};

dictionary HandwritingSegment {
  required DOMString grapheme;
  required unsigned long beginIndex;
  required unsigned long endIndex;
  required sequence<HandwritingDrawingSegment> drawingSegments;
};

dictionary HandwritingDrawingSegment {
  required unsigned long strokeIndex;
  required unsigned long beginPointIndex;
  required unsigned long endPointIndex;
};

Previous API

Feature Query

// V1 feature query, replaced by queryHandwritingRecognitionLanguage.
[CallWith=ScriptState, RaisesException]
partial interface Navigator {
  Promise<HandwritingFeatureQueryResult>
      queryHandwritingRecognizerSupport(HandwritingFeatureQuery query);
}

dictionary HandwritingFeatureQuery {
  sequence<DOMString> languages;
  any alternatives;
  any segmentationResult;
};

dictionary HandwritingFeatureQueryResult {
  boolean languages;
  boolean alternatives;
  boolean segmentationResult;
};