下面是如何確定哪些習俗的國家形態被點擊畫布上
首先,用photoshop來改變每個國家在地圖上爲不同的獨特的顏色(彩色編碼圖)
(別擔心,用戶不需要看到這個顏色編碼的地圖)。
然後,當用戶點擊畫布上,得到在clickpoint顏色和與貴國的顏色像這樣的比較:
function handleMouseDown(e){
mouseX=parseInt(e.clientX-offsetX);
mouseY=parseInt(e.clientY-offsetY);
var color=getPixelRGB(mouseX,mouseY);
if(isColorMatch(color,255,0,0)){ alert("You clicked on the red country"); }
if(isColorMatch(color,0,255,0)){ alert("You clicked on the green country"); }
if(isColorMatch(color,0,0,255)){ alert("You clicked on the blue country"); }
}
function isColorMatch(color,red,green,blue){
return(color.red==red && color.green==green && color.blue==blue);
}
function getPixelRGB(x, y) {
var pxData = ctx.getImageData(x,y,1,1);
var R = pxData.data[0];
var G = pxData.data[1];
var B = pxData.data[2];
return({red:R, green:G, blue:B});
}
您可能不希望顯示用戶的彩色編碼圖。如果沒有,您可以在與屏幕畫布相同的屏幕外畫布上創建顏色編碼的地圖 - 除了顏色編碼。當用戶點擊屏幕畫布時,只需在顏色編碼的地圖上檢查該像素位置即可。您可以獲得屏幕上的美容+屏幕外功能。
這裏的代碼和一個小提琴:http://jsfiddle.net/m1erickson/rmn5D/
請注意,此琴確實是因爲跨站點瀏覽器的安全警告,你將要替換自己的顏色編碼地圖的用戶不準確的地圖。
<!doctype html>
<html>
<head>
<link rel="stylesheet" type="text/css" media="all" href="css/reset.css" /> <!-- reset css -->
<script type="text/javascript" src="http://code.jquery.com/jquery.min.js"></script>
<style>
body{ background-color: ivory; }
canvas{border:1px solid red;}
</style>
<script>
$(function(){
var canvas=document.getElementById("canvas");
var ctx=canvas.getContext("2d");
var img=new Image();
img.onload=function(){
canvas.width=img.width;
canvas.height=img.height;
ctx.drawImage(img,0,0);
}
img.src="yourColorCodedMap.png";
var canvasOffset=$("#canvas").offset();
var offsetX=canvasOffset.left;
var offsetY=canvasOffset.top;
function handleMouseDown(e){
mouseX=parseInt(e.clientX-offsetX);
mouseY=parseInt(e.clientY-offsetY);
var color=getPixelRGB(mouseX,mouseY);
if(isColorMatch(color,255,0,0)){ alert("You clicked on the red country"); }
if(isColorMatch(color,0,255,0)){ alert("You clicked on the green country"); }
if(isColorMatch(color,0,0,255)){ alert("You clicked on the blue country"); }
}
function isColorMatch(color,red,green,blue){
return(color.red==red && color.green==green && color.blue==blue);
}
function getPixelRGB(x, y) {
var pxData = ctx.getImageData(x,y,1,1);
var R = pxData.data[0];
var G = pxData.data[1];
var B = pxData.data[2];
return({red:R, green:G, blue:B});
}
$("#canvas").mousedown(function(e){handleMouseDown(e);});
}); // end $(function(){});
</script>
</head>
<body>
<p>Click on a map location to get country</p>
<canvas id="canvas" width=300 height=300></canvas>
</body>
</html>
您的國家形狀是由您使用畫布路徑繪製的,還是僅僅是一個圖像? – markE 2013-04-07 18:01:16
這些模型是在Photoshop中繪製的,所以它們是圖像。 – 2013-04-07 19:56:15