Line data Source code
1 : /*
2 : * Copyright 2012 Google Inc.
3 : *
4 : * Use of this source code is governed by a BSD-style license that can be
5 : * found in the LICENSE file.
6 : */
7 :
8 : #ifndef SkBBoxHierarchy_DEFINED
9 : #define SkBBoxHierarchy_DEFINED
10 :
11 : #include "SkRect.h"
12 : #include "SkRefCnt.h"
13 : #include "SkTDArray.h"
14 :
15 : /**
16 : * Interface for a spatial data structure that stores axis-aligned bounding
17 : * boxes and allows efficient retrieval of intersections with query rectangles.
18 : */
19 : class SkBBoxHierarchy : public SkRefCnt {
20 : public:
21 0 : SkBBoxHierarchy() {}
22 0 : virtual ~SkBBoxHierarchy() {}
23 :
24 : /**
25 : * Insert N bounding boxes into the hierarchy.
26 : */
27 : virtual void insert(const SkRect[], int N) = 0;
28 :
29 : /**
30 : * Populate results with the indices of bounding boxes interesecting that query.
31 : */
32 : virtual void search(const SkRect& query, SkTDArray<int>* results) const = 0;
33 :
34 : virtual size_t bytesUsed() const = 0;
35 :
36 : // Get the root bound.
37 : virtual SkRect getRootBound() const = 0;
38 :
39 : private:
40 : typedef SkRefCnt INHERITED;
41 : };
42 :
43 : #endif
|