如何插入两个点,如x:0 y:0和x:14 y:9,并在直线上更改这些点之间的所有单元格的背景?并保持相对于桌子的宽度和高度?
填充表的示例:所以我想将红色块从x:0y:0连接到x:14 y:9的直线。 http://jsfiddle.net/qy09q4jv/8/
var table = $('<table>');
$('body').append(table);
var mx = 15;
var my = 10;
for(y = 0; y < my; y++){
var tr = $('<tr>');
for(x = 0; x < mx; x++){
var td = $('<td>');
td.attr('id', 'cell-'+x+'-'+y);
td.html("X:"+x + "Y:"+y);
tr.append(td);
}
$(table).append(tr);
}
这就是我现在所得到的:
<html>
<head>
<title>Test</title>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
</head>
<style>
table td{
border: 1px solid black;
background-color: #C8C8C8;
}
</style>
<body>
<ul>
</ul>
<script>
var table = $('<table>');
$('body').append(table);
var mx = 20;
var my = 20
for(y = 0; y < my; y++){
var tr = $('<tr>');
for(x = 0; x < mx; x++){
var td = $('<td>');
td.attr('id', 'cell-'+x+'-'+y);
td.html("X:"+x + "Y:"+y);
tr.append(td);
}
$(table).append(tr);
}
var startX = 0;
var startY = 0;
var endX = 14;
var endY = 9;
$("#cell-"+startX+"-"+startY).css('background-color', 'red');
$("#cell-"+endX+"-"+endY).css('background-color', 'red');
var distance = distance({x: startX, y: startY}, {x: endX, y: endY});
line(startX, startY, endX, endY);
function line(x0, y0, x1, y1) { //http://rosettacode.org/wiki/Bitmap/Bresenham%27s_line_algorithm#JavaScript
var dx = Math.abs(x1 - x0), sx = x0 < x1 ? 1 : -1;
var dy = Math.abs(y1 - y0), sy = y0 < y1 ? 1 : -1;
var err = (dx>dy ? dx : -dy)/2;
while (true) {
$("#cell-"+x0+"-"+x0).css('background-color', 'red');
if (x0 === x1 && y0 === y1) break;
var e2 = err;
if (e2 > -dx) { err -= dy; x0 += sx; }
if (e2 < dy) { err += dx; y0 += sy; }
}
}
</script>
</body>
</html>
我再次陷入困境:(
答案 0 :(得分:0)
如下:
function changeBG(xstart,xend, ystart, yend){
for(var x=xstart;x<=xend;x++){
for(var y=ystart;y<=yend;y++){
$("#cell-"+x+"-"+y).css("background", "yellow");
}
}
}
/* example */
changeBG(3,7,0,0);
http://jsfiddle.net/qy09q4jv/5/
没有足够的细节来确定范围的工作原理,但希望这有助于
注意:您可能需要添加其他检查,例如确保xstart等于或大于xend,与ystart和yend相同
答案 1 :(得分:0)
您可以执行类似
的操作var table = $('<table>');
$('body').append(table);
var mx = 15;
var my = 10;
for(y = 0; y < my; y++){
var tr = $('<tr>');
for(x = 0; x < mx; x++){
var td = $('<td>');
td.attr('id', 'cell-'+x+'-'+y);
td.html("X:"+x + "Y:"+y);
td.attr("data-x",x);
td.attr("data-y",y);
tr.append(td);
}
$(table).append(tr);
}
insertPoints({x:5,y:2},{x:1,y:8});
function insertPoints(p1,p2) {
$("table td").each(function(i,e){
console.log(e);
var x = parseInt($(e).data("x"));
var y = parseInt($(e).data("y"));
if ((x >= p1.x && y >= p1.y && y < p2.y) || (x <= p2.x && y > p1.y && y <= p2.y)){
$(e).css("background-color","red");
}
});
}
小提琴:http://jsfiddle.net/qy09q4jv/7/
请注意,检查单元格是否在这些值之间是不完美的,但它应该给你一个正确方向的提示;)
答案 2 :(得分:0)
您必须使用Bresenham's line alogrithm
尝试使用此代码或使用此jsfiddle
var a = [0,0];
var b = [14,9];
// coordinates between two points
var coordinates = [];
var deltax = b[0] - a[0];
var deltay = b[1] - a[1];
var y = a[1];
var error = 0;
var deltaError = Math.abs(deltay/deltax);
// x axis
for(var x = a[0]; x <= b[0]; x++){
coordinates.push([x,y]);
error = error + deltaError;
if(error >= 0.5){
y = y + 1
error = error - 1;
}
}
var containsCoordinate = (function (coordArray) {
return function (x,y) {
for (var i = 0; i < coordArray.length; i++) {
if (coordArray[i][0] == x && coordArray[i][1] == y) {
return true;
}
}
return false;
}
})(coordinates);
var table = $('<table>');
$('body').append(table);
var mx = 15;
var my = 10;
for(y = 0; y < my; y++){
var tr = $('<tr>');
for(x = 0; x < mx; x++){
var td = $('<td>');
td.attr('id', 'cell-'+x+'-'+y);
td.html("X:"+x + "Y:"+y);
if(containsCoordinate(x,y)){
td.css("background-color","yellow");
}
tr.append(td);
}
$(table).append(tr);
}
希望这有帮助,