mirror of https://github.com/OpenTTD/OpenTTD
(svn r10070) -Fix: fix the rounding problem of zoom-levels in zoom.hpp, so it is global for every call
parent
d3a7fb8d73
commit
98c3056aa6
|
@ -856,7 +856,7 @@ static inline void GfxBlitTileZoom(BlitterParams *bp)
|
||||||
if (num <= 0) continue;
|
if (num <= 0) continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
num = UnScaleByZoom(num + ScaleByZoom(1, Tzoom) - 1, Tzoom);
|
num = UnScaleByZoom(num, Tzoom);
|
||||||
|
|
||||||
switch (Tmode) {
|
switch (Tmode) {
|
||||||
case BM_COLOUR_REMAP:
|
case BM_COLOUR_REMAP:
|
||||||
|
|
|
@ -37,14 +37,14 @@ static inline int ScaleByZoom(int value, ZoomLevel zoom)
|
||||||
{
|
{
|
||||||
if (zoom == ZOOM_LVL_NORMAL) return value;
|
if (zoom == ZOOM_LVL_NORMAL) return value;
|
||||||
int izoom = (int)zoom - (int)ZOOM_LVL_NORMAL;
|
int izoom = (int)zoom - (int)ZOOM_LVL_NORMAL;
|
||||||
return (zoom > ZOOM_LVL_NORMAL) ? value << izoom : value >> -izoom;
|
return (zoom > ZOOM_LVL_NORMAL) ? value << izoom : (value + (1 << -izoom)) >> -izoom;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int UnScaleByZoom(int value, ZoomLevel zoom)
|
static inline int UnScaleByZoom(int value, ZoomLevel zoom)
|
||||||
{
|
{
|
||||||
if (zoom == ZOOM_LVL_NORMAL) return value;
|
if (zoom == ZOOM_LVL_NORMAL) return value;
|
||||||
int izoom = (int)zoom - (int)ZOOM_LVL_NORMAL;
|
int izoom = (int)zoom - (int)ZOOM_LVL_NORMAL;
|
||||||
return (zoom > ZOOM_LVL_NORMAL) ? value >> izoom : value << -izoom;
|
return (zoom > ZOOM_LVL_NORMAL) ? (value + (1 << izoom) - 1) >> izoom : value << -izoom;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* ZOOM_HPP */
|
#endif /* ZOOM_HPP */
|
||||||
|
|
Loading…
Reference in New Issue