I have a question i know a line i just know its slope(m) and a point on it A(x,y) How can i calculate the points(actually two of them) on this line with a distance(d) from point A ??? I m asking this for finding intensity of pixels on a line that pass through A(x,y) with a distance .Distance in this case will be number of pixels.
相关问题
- Direct2D Only Partially Linking in C++ Builder
- Set *both* elements and initial capacity of std::v
- Name for a method that has only side effects
- Is it more efficient to set the size of a vector u
- Asynchronous threads drawing in Bitmaps Delphi
相关文章
- How do I get characters common to two vectors in C
- Should client-server code be written in one “proje
- Algorithm for maximizing coverage of rectangular a
- Behavior of uniforms after glUseProgram() and spee
- How can I unpack (destructure) elements from a vec
- Is there an existing solution for these particular
- How to smooth the blocks of a 3D voxel world?
- What is Scope Creep? [closed]
Let me explain the answer in a simple way.
Start point -
(x0, y0)
End point -
(x1, y1)
We need to find a point
(xt, yt)
at a distance dt from start point towards end point.The distance between Start and End point is given by
d = sqrt((x1 - x0)^2 + (y1 - y0)^2)
Let the ratio of distances,
t = dt / d
Then the point
(xt, yt) = (((1 - t) * x0 + t * x1), ((1 - t) * y0 + t * y1))
When
0 < t < 1
, the point is on the line.When
t < 0
, the point is outside the line near to(x0, y0)
.When
t > 1
, the point is outside the line near to(x1, y1)
.Let's call the point you are trying to find P, with coordinates px, py, and your starting point A's coordinates ax and ay. Slope m is just the ratio of the change in Y over the change in X, so if your point P is distance s from A, then its coordinates are px = ax + s, and py = ay + m * s. Now using Pythagoras, the distance d from A to P will be d = sqrt(s * s + (m * s) * (m * s)). To make P be a specific D units away from A, find s as s = D/sqrt(1 + m * m).
I would suggest converting the line to a parametric format instead of point-slope. That is, a parametric function for the line returns points along that line for the value of some parameter t. You can represent the line as a reference point, and a vector representing the direction of the line going through that point. That way, you just travel d units forward and backward from point A to get your other points.
Since your line has slope m, its direction vector is <1, m>. Since it moves m pixels in y for every 1 pixel in x. You want to normalize that direction vector to be unit length so you divide by the magnitude of the vector.
The normalized direction vector is N. Now you are almost done. You just need to write the equation for your line in parameterized format:
This uses vector math. Specifically, scalar vector multiplication (of your parameter t and the vector N) and vector addition (of A and t*N). The result of the function f is a point along the line. The 2 points you are looking for are f(d) and f(-d). Implement that in the language of your choosing.
The advantage to using this method, as opposed to all the other answers so far, is that you can easily extend this method to support a line with "infinite" slope. That is, a vertical line like x = 3. You don't really need the slope, all you need is the normalized direction vector. For a vertical line, it is <0, 1>. This is why graphics operations often use vector math, because the calculations are more straight-forward and less prone to singularities. It may seem a little complicated at first, but once you get the hang of vector operations, a lot of computer graphics tasks get a lot easier.
I thought this was an awesome and easy to understand solution:
http://www.physicsforums.com/showpost.php?s=f04d131386fbd83b7b5df27f8da84fa1&p=2822353&postcount=4