编辑 我已经弄清楚出了什么问题。如果你想看看你是否也能找到它,请随意。否则我在答案中发布了答案。
我将继续发布所有代码,因为我之前已经问过这个问题,但忽略了我认为对发现问题没有必要的东西,但回答者想要所有代码。
下面的代码模仿了我的一些其他代码,它工作得很好,但是在这种方法中它不想工作。我有一个名为的初始 div #container
,它是俄克拉荷马州地图的图像,在该图像上您可以看到该州的不同部分。在我的旧代码中,当用户单击段的某个区域时,它会#container
关闭 div 并打开该段的“放大”图片的图像的 div。在我的新代码应该使我的代码更简洁之后,它不会#container
关闭(我怀疑不会打开新的 div)。
#region
我通过在用户单击时使用鼠标位置来确定要打开哪个段 ( )。我使用像素坐标,并且我已经完成了数学运算来缩放这些坐标,因此屏幕大小无关紧要。
现在,这是新的和错误的代码:
$(document).ready(function()
{
//Main Oklahoma map
$("#container").click(function(e)
{
var x = event.pageX;
var y = event.pageY;
const scaling_Screen_Max_Pixel_X = 1679;
const scaling_Screen_Max_Pixel_Y = 924;
// Math for the scaling of different sized windows
var currentX = $(document).width();
var currentY = $(document).height();
var xScale = currentX/scaling_Screen_Max_Pixel_X;
var yScale = currentY/scaling_Screen_Max_Pixel_Y;
// Variables for different regions
var zoneX = x/xScale;
var zoneY = y/yScale;
// Arrays containing the min and max x and y values of the rectangular area around a farm
var minX = [47, 593, 593, 958, 600, 744, 852, 1025, 1060, 1159, 1366];
var maxX = [553, 958, 792, 1011, 1124, 1124, 1149, 1598, 1280, 1623, 1551];
var minY = [250, 250, 473, 349, 526, 665, 495, 248, 471, 520, 481];
var maxY = [330, 473, 515, 478, 665, 721, 526, 471, 500, 763, 520];
var regionNumber = [1,2,2,2,3,3,3,4,4,5,5];
/** Loops through the values within the coordinate arrays to
determine if the user clicked within a certain area **/
for (var i = 0; i < minX.length; i++)
{
if(zoneX >= minX[i] && zoneX <= maxX[i] && zoneY >= minY[i] && zoneY <= maxY[i])
{
$("#region"+region[i]).toggle();
$("#container").toggle(); //toggle off
}
}
});
});
minX、maxX 等数组中的坐标是有序的,因此这四个数组中的每个数组中的第一个元素都属于第一个区域 ( #region1
)。我有regionNumber
数组的原因是因为我有多个区域的“矩形”坐标集,因为这些区域不是完美的矩形。
正如我之前所说,当我单击一个区域时没有任何反应。你明白这里有什么问题吗?