Mercurial > hg > svcore
comparison data/model/PowerOfTwoZoomConstraint.cpp @ 1450:a12fd0456f0c streaming-csv-writer
Merge from default branch
author | Chris Cannam |
---|---|
date | Tue, 17 Apr 2018 10:35:42 +0100 |
parents | 48e9f538e6e9 |
children | 710e6250a401 a7485c1bdba5 |
comparison
equal
deleted
inserted
replaced
1449:deabf9fd3d28 | 1450:a12fd0456f0c |
---|---|
15 | 15 |
16 #include "PowerOfTwoZoomConstraint.h" | 16 #include "PowerOfTwoZoomConstraint.h" |
17 | 17 |
18 int | 18 int |
19 PowerOfTwoZoomConstraint::getNearestBlockSize(int req, | 19 PowerOfTwoZoomConstraint::getNearestBlockSize(int req, |
20 RoundingDirection dir) const | 20 RoundingDirection dir) const |
21 { | 21 { |
22 int result = 0; | 22 int result = 0; |
23 | 23 |
24 for (int bs = 1; ; bs *= 2) { | 24 for (int bs = 1; ; bs *= 2) { |
25 if (bs >= req) { | 25 if (bs >= req) { |
26 if (dir == RoundNearest) { | 26 if (dir == RoundNearest) { |
27 if (bs - req < req - bs/2) { | 27 if (bs - req < req - bs/2) { |
28 result = bs; | 28 result = bs; |
29 break; | 29 break; |
30 } else { | 30 } else { |
31 result = bs/2; | 31 result = bs/2; |
32 break; | 32 break; |
33 } | 33 } |
34 } else if (dir == RoundDown) { | 34 } else if (dir == RoundDown) { |
35 result = bs/2; | 35 result = bs/2; |
36 break; | 36 break; |
37 } else { | 37 } else { |
38 result = bs; | 38 result = bs; |
39 break; | 39 break; |
40 } | 40 } |
41 } | 41 } |
42 } | 42 } |
43 | 43 |
44 if (result > getMaxZoomLevel()) result = getMaxZoomLevel(); | 44 if (result > getMaxZoomLevel()) result = getMaxZoomLevel(); |
45 return result; | 45 return result; |
46 } | 46 } |