Renamed RenderTarget::convertCoords to mapPixelToCoords, and added its inverse mapCoordsToPixel
This commit is contained in:
parent
044eb85872
commit
6ce6014dd8
|
@ -129,52 +129,102 @@ public :
|
||||||
IntRect getViewport(const View& view) const;
|
IntRect getViewport(const View& view) const;
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
/// \brief Convert a point from target coordinates to view coordinates
|
/// \brief Convert a point from target coordinates to world
|
||||||
|
/// coordinates, using the current view
|
||||||
///
|
///
|
||||||
/// Initially, a unit of the 2D world matches a pixel of the
|
/// This function is an overload of the mapPixelToCoords
|
||||||
/// render target. But if you define a custom view, this
|
/// function that implicitely uses the current view.
|
||||||
/// assertion is not true anymore, ie. a point located at
|
/// It is equivalent to:
|
||||||
/// (10, 50) in your render target (for example a window) may
|
/// \code
|
||||||
/// map to the point (150, 75) in your 2D world -- for example
|
/// target.mapPixelToCoords(point, target.getView());
|
||||||
/// if the view is translated by (140, 25).
|
/// \endcode
|
||||||
///
|
///
|
||||||
/// For render windows, this function is typically used to find
|
/// \param point Pixel to convert
|
||||||
/// which point (or object) is located below the mouse cursor.
|
|
||||||
///
|
///
|
||||||
/// This version uses the current view of the render target.
|
/// \return The converted point, in "world" coordinates
|
||||||
/// See the other overload to specify a custom view.
|
|
||||||
///
|
///
|
||||||
/// \param point Point to convert, relative to the render target
|
/// \see mapCoordsToPixel
|
||||||
///
|
|
||||||
/// \return The converted point, in "world" units
|
|
||||||
///
|
///
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
Vector2f convertCoords(const Vector2i& point) const;
|
Vector2f mapPixelToCoords(const Vector2i& point) const;
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
/// \brief Convert a point from target coordinates to view coordinates
|
/// \brief Convert a point from target coordinates to world coordinates
|
||||||
///
|
///
|
||||||
/// Initially, a unit of the 2D world matches a pixel of the
|
/// This function finds the 2D position that matches the
|
||||||
/// render target. But if you define a custom view, this
|
/// given pixel of the render-target. In other words, it does
|
||||||
/// assertion is not true anymore, ie. a point located at
|
/// the inverse of what the graphics card does, to find the
|
||||||
/// (10, 50) in your render target (for example a window) may
|
/// initial position of a rendered pixel.
|
||||||
/// map to the point (150, 75) in your 2D world -- for example
|
|
||||||
/// if the view is translated by (140, 25).
|
|
||||||
///
|
///
|
||||||
/// For render windows, this function is typically used to find
|
/// Initially, both coordinate systems (world units and target pixels)
|
||||||
|
/// match perfectly. But if you define a custom view or resize your
|
||||||
|
/// render-target, this assertion is not true anymore, ie. a point
|
||||||
|
/// located at (10, 50) in your render-target may map to the point
|
||||||
|
/// (150, 75) in your 2D world -- if the view is translated by (140, 25).
|
||||||
|
///
|
||||||
|
/// For render-windows, this function is typically used to find
|
||||||
/// which point (or object) is located below the mouse cursor.
|
/// which point (or object) is located below the mouse cursor.
|
||||||
///
|
///
|
||||||
/// This version uses a custom view for calculations, see the other
|
/// This version uses a custom view for calculations, see the other
|
||||||
/// overload of the function to use the current view of the render
|
/// overload of the function if you want to use the current view of the
|
||||||
/// target.
|
/// render-target.
|
||||||
///
|
///
|
||||||
/// \param point Point to convert, relative to the render target
|
/// \param point Pixel to convert
|
||||||
/// \param view The view to use for converting the point
|
/// \param view The view to use for converting the point
|
||||||
///
|
///
|
||||||
/// \return The converted point, in "world" units
|
/// \return The converted point, in "world" units
|
||||||
///
|
///
|
||||||
|
/// \see mapCoordsToPixel
|
||||||
|
///
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
Vector2f convertCoords(const Vector2i& point, const View& view) const;
|
Vector2f mapPixelToCoords(const Vector2i& point, const View& view) const;
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
/// \brief Convert a point from world coordinates to target
|
||||||
|
/// coordinates, using the current view
|
||||||
|
///
|
||||||
|
/// This function is an overload of the mapCoordsToPixel
|
||||||
|
/// function that implicitely uses the current view.
|
||||||
|
/// It is equivalent to:
|
||||||
|
/// \code
|
||||||
|
/// target.mapCoordsToPixel(point, target.getView());
|
||||||
|
/// \endcode
|
||||||
|
///
|
||||||
|
/// \param point Point to convert
|
||||||
|
///
|
||||||
|
/// \return The converted point, in target coordinates (pixels)
|
||||||
|
///
|
||||||
|
/// \see mapPixelToCoords
|
||||||
|
///
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
Vector2i mapCoordsToPixel(const Vector2f& point) const;
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
/// \brief Convert a point from world coordinates to target coordinates
|
||||||
|
///
|
||||||
|
/// This function finds the pixel of the render-target that matches
|
||||||
|
/// the given 2D point. In other words, it goes through the same process
|
||||||
|
/// as the graphics card, to compute the final position of a rendered point.
|
||||||
|
///
|
||||||
|
/// Initially, both coordinate systems (world units and target pixels)
|
||||||
|
/// match perfectly. But if you define a custom view or resize your
|
||||||
|
/// render-target, this assertion is not true anymore, ie. a point
|
||||||
|
/// located at (150, 75) in your 2D world may map to the pixel
|
||||||
|
/// (10, 50) of your render-target -- if the view is translated by (140, 25).
|
||||||
|
///
|
||||||
|
/// This version uses a custom view for calculations, see the other
|
||||||
|
/// overload of the function if you want to use the current view of the
|
||||||
|
/// render-target.
|
||||||
|
///
|
||||||
|
/// \param point Point to convert
|
||||||
|
/// \param view The view to use for converting the point
|
||||||
|
///
|
||||||
|
/// \return The converted point, in target coordinates (pixels)
|
||||||
|
///
|
||||||
|
/// \see mapPixelToCoords
|
||||||
|
///
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
Vector2i mapCoordsToPixel(const Vector2f& point, const View& view) const;
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
/// \brief Draw a drawable object to the render-target
|
/// \brief Draw a drawable object to the render-target
|
||||||
|
|
|
@ -100,25 +100,45 @@ IntRect RenderTarget::getViewport(const View& view) const
|
||||||
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
Vector2f RenderTarget::convertCoords(const Vector2i& point) const
|
Vector2f RenderTarget::mapPixelToCoords(const Vector2i& point) const
|
||||||
{
|
{
|
||||||
return convertCoords(point, getView());
|
return mapPixelToCoords(point, getView());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
Vector2f RenderTarget::convertCoords(const Vector2i& point, const View& view) const
|
Vector2f RenderTarget::mapPixelToCoords(const Vector2i& point, const View& view) const
|
||||||
{
|
{
|
||||||
// First, convert from viewport coordinates to homogeneous coordinates
|
// First, convert from viewport coordinates to homogeneous coordinates
|
||||||
Vector2f coords;
|
Vector2f normalized;
|
||||||
IntRect viewport = getViewport(view);
|
IntRect viewport = getViewport(view);
|
||||||
coords.x = -1.f + 2.f * (point.x - viewport.left) / viewport.width;
|
normalized.x = -1.f + 2.f * (point.x - viewport.left) / viewport.width;
|
||||||
coords.y = 1.f - 2.f * (point.y - viewport.top) / viewport.height;
|
normalized.y = 1.f - 2.f * (point.y - viewport.top) / viewport.height;
|
||||||
|
|
||||||
// Then transform by the inverse of the view matrix
|
// Then transform by the inverse of the view matrix
|
||||||
return view.getInverseTransform().transformPoint(coords);
|
return view.getInverseTransform().transformPoint(normalized);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
Vector2i RenderTarget::mapCoordsToPixel(const Vector2f& point) const
|
||||||
|
{
|
||||||
|
return mapCoordsToPixel(point, getView());
|
||||||
|
}
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
Vector2i RenderTarget::mapCoordsToPixel(const Vector2f& point, const View& view) const
|
||||||
|
{
|
||||||
|
// First, transform the point by the view matrix
|
||||||
|
Vector2f normalized = view.getTransform().transformPoint(point);
|
||||||
|
|
||||||
|
// Then convert to viewport coordinates
|
||||||
|
Vector2i pixel;
|
||||||
|
IntRect viewport = getViewport(view);
|
||||||
|
pixel.x = static_cast<int>(( normalized.x + 1.f) / 2.f * viewport.width + viewport.left);
|
||||||
|
pixel.y = static_cast<int>((-normalized.y + 1.f) / 2.f * viewport.height + viewport.top);
|
||||||
|
|
||||||
|
return pixel;
|
||||||
|
}
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void RenderTarget::draw(const Drawable& drawable, const RenderStates& states)
|
void RenderTarget::draw(const Drawable& drawable, const RenderStates& states)
|
||||||
|
|
Loading…
Reference in a new issue