aboutsummaryrefslogtreecommitdiffhomepage
path: root/experimental/skpdiff/SkImageDiffer.h
diff options
context:
space:
mode:
Diffstat (limited to 'experimental/skpdiff/SkImageDiffer.h')
-rw-r--r--experimental/skpdiff/SkImageDiffer.h97
1 files changed, 97 insertions, 0 deletions
diff --git a/experimental/skpdiff/SkImageDiffer.h b/experimental/skpdiff/SkImageDiffer.h
new file mode 100644
index 0000000000..6c570cbb8e
--- /dev/null
+++ b/experimental/skpdiff/SkImageDiffer.h
@@ -0,0 +1,97 @@
+/*
+ * Copyright 2013 Google Inc.
+ *
+ * Use of this source code is governed by a BSD-style license that can be
+ * found in the LICENSE file.
+ */
+
+#ifndef SkImageDiffer_DEFINED
+#define SkImageDiffer_DEFINED
+
+class SkBitmap;
+struct SkIPoint;
+
+/**
+ * Encapsulates an image difference metric algorithm that can be potentially run asynchronously.
+ */
+class SkImageDiffer {
+public:
+ SkImageDiffer();
+ virtual ~SkImageDiffer();
+
+ /**
+ * Gets a unique and descriptive name of this differ
+ * @return A statically allocated null terminated string that is the name of this differ
+ */
+ virtual const char* getName() = 0;
+
+ /**
+ * Gets if this differ is in a usable state
+ * @return True if this differ can be used, false otherwise
+ */
+ bool isGood() { return fIsGood; }
+
+ /**
+ * Gets if this differ needs to be initialized with and OpenCL device and context.
+ */
+ virtual bool requiresOpenCL() { return false; }
+
+ /**
+ * Wraps a call to queueDiff by loading the given filenames into SkBitmaps
+ * @param baseline The file path of the baseline image
+ * @param test The file path of the test image
+ * @return The results of queueDiff with the loaded bitmaps
+ */
+ int queueDiffOfFile(const char baseline[], const char test[]);
+
+ /**
+ * Queues a diff on a pair of bitmaps to be done at some future time.
+ * @param baseline The correct bitmap
+ * @param test The bitmap whose difference is being tested
+ * @return An non-negative diff ID on success, a negative integer on failure.
+ */
+ virtual int queueDiff(SkBitmap* baseline, SkBitmap* test) = 0;
+
+ /**
+ * Gets whether a queued diff of the given id has finished
+ * @param id The id of the queued diff to query
+ * @return True if the queued diff is finished and has results, false otherwise
+ */
+ virtual bool isFinished(int id) = 0;
+
+ /**
+ * Deletes memory associated with a diff and its results. This may block execution until the
+ * diff is finished,
+ * @param id The id of the diff to query
+ */
+ virtual void deleteDiff(int id) = 0;
+
+ /**
+ * Gets the results of the queued diff of the given id. The results are only meaningful after
+ * the queued diff has finished.
+ * @param id The id of the queued diff to query
+ */
+ virtual double getResult(int id) = 0;
+
+ /**
+ * Gets the number of points of interest for the diff of the given id. The results are only
+ * meaningful after the queued diff has finished.
+ * @param id The id of the queued diff to query
+ */
+ virtual int getPointsOfInterestCount(int id) = 0;
+
+ /**
+ * Gets an array of the points of interest for the diff of the given id. The results are only
+ * meaningful after the queued diff has finished.
+ * @param id The id of the queued diff to query
+ */
+ virtual SkIPoint* getPointsOfInterest(int id) = 0;
+
+
+
+protected:
+ bool fIsGood;
+};
+
+
+#endif