# HG changeset patch # User spq@33b003aa-7bff-0310-803a-e67f0ece8222 # Date 1223839390 0 # Node ID 29309cd5e240ec5312f34965501eb9f25fc030df # Parent d29593182f409370b2d5baa227420fee9736613b fix searching for instances in a rect - old code had false positives diff -r d29593182f40 -r 29309cd5e240 engine/core/view/camera.cpp --- a/engine/core/view/camera.cpp Sat Oct 11 14:13:56 2008 +0000 +++ b/engine/core/view/camera.cpp Sun Oct 12 19:23:10 2008 +0000 @@ -337,23 +337,25 @@ Uint8 r, g, b, a; for(int xx = screen_rect.x; xx < screen_rect.x + screen_rect.w; xx++) { for(int yy = screen_rect.y; yy < screen_rect.y + screen_rect.h; yy++) { - int x = xx - vc.dimensions.x; - int y = yy - vc.dimensions.y; - if (m_zoom != 1.0) { - double fx = static_cast(x); - double fy = static_cast(y); - double fow = static_cast(vc.image->getWidth()); - double foh = static_cast(vc.image->getHeight()); - double fsw = static_cast(vc.dimensions.w); - double fsh = static_cast(vc.dimensions.h); - x = static_cast(round(fx / fsw * fow)); - y = static_cast(round(fy / fsh * foh)); - } - vc.image->getPixelRGBA(x, y, &r, &g, &b, &a); - // instance is hit with mouse if not totally transparent - if (a != 0) { - instances.push_back(i); - goto found_non_transparent_pixel; + if ((vc.dimensions.contains(Point(xx, yy)))) { + int x = xx - vc.dimensions.x; + int y = yy - vc.dimensions.y; + if (m_zoom != 1.0) { + double fx = static_cast(x); + double fy = static_cast(y); + double fow = static_cast(vc.image->getWidth()); + double foh = static_cast(vc.image->getHeight()); + double fsw = static_cast(vc.dimensions.w); + double fsh = static_cast(vc.dimensions.h); + x = static_cast(round(fx / fsw * fow)); + y = static_cast(round(fy / fsh * foh)); + } + vc.image->getPixelRGBA(x, y, &r, &g, &b, &a); + // instance is hit with mouse if not totally transparent + if (a != 0) { + instances.push_back(i); + goto found_non_transparent_pixel; + } } } }