Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(121)

Unified Diff: third_party/WebKit/Source/modules/shapedetection/ShapeDetector.h

Issue 2557513003: ShapeDetection: Eliminate DetectorType enum in ShapeDetector.cpp (Closed)
Patch Set: Created 4 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: third_party/WebKit/Source/modules/shapedetection/ShapeDetector.h
diff --git a/third_party/WebKit/Source/modules/shapedetection/ShapeDetector.h b/third_party/WebKit/Source/modules/shapedetection/ShapeDetector.h
index 744007a8d8427dc3bf74b48b16217f40e533d5a3..5a8213f5b392ebc90b5b2c6ca65ce0ab2567747f 100644
--- a/third_party/WebKit/Source/modules/shapedetection/ShapeDetector.h
+++ b/third_party/WebKit/Source/modules/shapedetection/ShapeDetector.h
@@ -9,9 +9,6 @@
#include "bindings/core/v8/ScriptPromiseResolver.h"
#include "modules/ModulesExport.h"
#include "modules/canvas2d/CanvasRenderingContext2D.h"
-#include "modules/shapedetection/FaceDetectorOptions.h"
-#include "public/platform/modules/shapedetection/barcodedetection.mojom-blink.h"
-#include "public/platform/modules/shapedetection/facedetection.mojom-blink.h"
namespace blink {
@@ -20,55 +17,32 @@ class LocalFrame;
class MODULES_EXPORT ShapeDetector
: public GarbageCollectedFinalized<ShapeDetector> {
public:
- enum class DetectorType {
- Face,
- Barcode
- // TODO(mcasas): Implement TextDetector after
- // https://github.com/WICG/shape-detection-api/issues/6
- };
+ // TODO(mcasas): Implement TextDetector after
+ // https://github.com/WICG/shape-detection-api/issues/6
explicit ShapeDetector(LocalFrame&);
- ShapeDetector(LocalFrame&, const FaceDetectorOptions&);
virtual ~ShapeDetector() = default;
- ScriptPromise detectShapes(ScriptState*,
- DetectorType,
+ virtual ScriptPromise detect(ScriptState*, const CanvasImageSourceUnion&) = 0;
+ bool preprocessImageSource(ScriptState*,
+ ScriptPromiseResolver*,
const CanvasImageSourceUnion&);
- DECLARE_VIRTUAL_TRACE();
+ DEFINE_INLINE_VIRTUAL_TRACE() {}
private:
- ScriptPromise detectShapesOnImageElement(DetectorType,
- ScriptPromiseResolver*,
- const HTMLImageElement*);
- ScriptPromise detectShapesOnImageBitmap(DetectorType,
- ScriptPromiseResolver*,
- ImageBitmap*);
- ScriptPromise detectShapesOnVideoElement(DetectorType,
- ScriptPromiseResolver*,
- const HTMLVideoElement*);
+ bool preprocessImageElement(ScriptPromiseResolver*, const HTMLImageElement*);
+ bool preprocessImageBitmap(ScriptPromiseResolver*, ImageBitmap*);
+ bool preprocessVideoElement(ScriptPromiseResolver*, const HTMLVideoElement*);
- ScriptPromise detectShapesOnData(DetectorType,
- ScriptPromiseResolver*,
- uint8_t* data,
- int size,
- int width,
- int height);
- void onDetectFaces(ScriptPromiseResolver*,
- mojom::blink::FaceDetectionResultPtr);
- void onDetectBarcodes(ScriptPromiseResolver*,
- Vector<mojom::blink::BarcodeDetectionResultPtr>);
-
- // Error handlers for use if mojo service doesn't connect.
- void onFaceServiceConnectionError();
- void onBarcodeServiceConnectionError();
-
- mojom::blink::FaceDetectionPtr m_faceService;
- mojom::blink::BarcodeDetectionPtr m_barcodeService;
-
- HeapHashSet<Member<ScriptPromiseResolver>> m_faceServiceRequests;
- HeapHashSet<Member<ScriptPromiseResolver>> m_barcodeServiceRequests;
+ bool getSharedBufferOnData(ScriptPromiseResolver*,
+ uint8_t* data,
+ int size,
+ int width,
+ int height);
protected:
- mojom::blink::FaceDetectorOptionsPtr m_faceDetectorOptions;
+ uint32_t m_imageWidth;
+ uint32_t m_imageHeight;
+ mojo::ScopedSharedBufferHandle m_sharedBufferHandle;
};
} // namespace blink

Powered by Google App Engine
This is Rietveld 408576698