У меня есть вкладка рисования холста и хочу, чтобы lineWidth был основан на расстоянии между двумя последними обновлениями координат mousemove. Я сделаю перевод расстояния до самой ширины, мне просто нужно знать, как получить расстояние между этими точками (у меня уже есть координаты этих точек).Получите расстояние между двумя точками в холсте
ответ
Вы можете сделать это с теоремой Пифагора
Если у вас есть две точки (x1, y1) и (x2, y2) , то вы можете рассчитать разность x и разницу в y, позвоните по ним a и b.
var a = x1 - x2
var b = y1 - y2
var c = Math.sqrt(a*a + b*b);
// c is the distance
http://en.wikipedia.org/wiki/Euclidean_distance
Если у вас есть координаты, использовать формулу для вычисления расстояния:
var dist = Math.sqrt(Math.pow((x1-x2), 2) + Math.pow((y1-y2), 2));
я предпочитаю использовать этот расчет много в вещах я сделать, так что я хотел бы добавить его к объекту Math:
Math.dist=function(x1,y1,x2,y2){
if(!x2) x2=0;
if(!y2) y2=0;
return Math.sqrt((x2-x1)*(x2-x1)+(y2-y1)*(y2-y1));
}
Math.dist(0,0, 3,4); //the output will be 5
Math.dist(1,1, 4,5); //the output will be 5
Math.dist(3,4); //the output will be 5
Update:
Этот подход особенно радует, когда вы оказываетесь в ситуациях, похожих на это (я часто делаю):
varName.dist=Math.sqrt(((varName.paramX-varX)/2-cx)*((varName.paramX-varX)/2-cx) + ((varName.paramY-varY)/2-cy)*((varName.paramY-varY)/2-cy));
что противная вещь становится гораздо более управляемым:
varName.dist=Math.dist((varName.paramX-varX)/2, (varName.paramY-varY)/2, cx, cy);
Обратите внимание, что Math.hypot
является частью стандарта ES2015. Для этой функции также есть хороший полиполк на MDN doc.
Так что получение расстояния становится таким же простым, как и Math.hypot(x2-x1, y2-y1)
.
Расстояние между двумя координатами x и y! x1 и y1 - первая точка/позиция, x2 и y2 - вторая точка/позиция!
function diff (num1, num2) {
if (num1 > num2) {
return (num1 - num2);
} else {
return (num2 - num1);
}
};
function dist (x1, y1, x2, y2) {
var deltaX = diff(x1, x2);
var deltaY = diff(y1, y2);
var dist = Math.sqrt(Math.pow(deltaX, 2) + Math.pow(deltaY, 2));
return (dist);
};
Вы должны использовать 'Math.abs' вместо' diff'. –
- 1. Получите расстояние между двумя точками
- 2. Расстояние между двумя точками
- 3. Android вычислить длину или расстояние между двумя точками в холсте
- 4. CesiumJS - Расстояние между двумя точками
- 5. Gps расстояние между двумя точками
- 6. Вычислить расстояние между двумя точками
- 7. Геодезическое расстояние между двумя точками
- 8. Рассчитать расстояние между двумя точками
- 9. Рассчитать расстояние между двумя точками
- 10. Расстояние между двумя географическими точками?
- 11. Улей: Расстояние между двумя точками
- 12. Android расстояние между двумя точками
- 13. Расстояние между двумя точками, используя расстояние формулу
- 14. Получите метрическое расстояние между двумя точками через запрос PostgreSQL/PostGIS
- 15. Получите расстояние между двумя географическими точками - автономная карта
- 16. Получите расстояние между двумя точками, используя API Карт Google
- 17. Зарисуйте кривую между двумя точками в холсте
- 18. Рассчитать расстояние между двумя точками в java
- 19. расстояние между двумя точками изображения в Matlab
- 20. Наибольшее расстояние между двумя точками в массиве
- 21. Рассчитать расстояние в метрах между двумя точками
- 22. Расстояние между двумя точками в javascript
- 23. расстояние между двумя точками в прологе
- 24. Определить расстояние между двумя точками в jsp
- 25. Получите расстояние между точками буксировки в слоях 3 в метрах
- 26. Перемещение между двумя точками на холсте
- 27. реальное расстояние между двумя точками над изображением
- 28. Установите область на расстояние между двумя точками
- 29. Рассчитать расстояние на сетке между двумя точками
- 30. Найти расстояние между двумя точками (lat/long)
+1 фантазии ** и ** правильно ... Ницца! – markE
Ничего себе, совсем забыл о теореме Пифагора. +1 – Anagmate
Я думаю, что путь под «обновлением» может испортить некоторые люди, так как каждый раз он будет изменять значение x2 и y2. лучше не представлять это как общее решение IMHO. – jaya