gpt4 book ai didi

javascript - 如何从来自不同域或服务器的图像中获取颜色?

转载 作者:太空宇宙 更新时间:2023-11-04 14:27:53 26 4
gpt4 key购买 nike

我试图在用户点击的位置从图像中选择一种颜色。但传统方式即 Canvas 限制我访问我的图像文件直接来 self 的 parse.com 数据库,即 "http://files/kj.jpg" 显示错误为:

无法从 Canvas 获取图像数据,因为 Canvas 已被跨源数据污染。欢迎:1ImageColor Picker:无法访问图像数据。这可能是由于您使用的浏览器(IE 不工作)或图像和脚本保存在不同的服务器上或您在本地运行脚本。

这是由于图像的 url。但是我们必须使用相同的 url,因为我们不能每次都在本地将图像保存到客户端 pc,因为这会降低应用程序的质量。

我正在寻找的是有什么方法可以让我获得点击点的颜色。如果否,请提出任何替代方案。

谢谢你,桑托什乌帕哈耶

最佳答案

您遇到跨源安全违规(CORS 违规)。

也许最简单的解决方法是将您的图像托管在允许匿名下载图像的站点上。这样就不会触发 CORS 错误,您的颜色选择器就可以工作了。

其中一个网站是 Dropbox.com。

您唯一需要做的应用更改是将图像的 crossOrigin 标志设置为匿名。

// create a new image object

var img=new Image();

// set its crossOrigin flag to anonymous
// to allow downloading from dropbox.com (or any X-domain enabled site)

img.crossOrigin="anonymous";

这是完整的代码和 fiddle :http://jsfiddle.net/m1erickson/y2P79/

<!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; padding:20px;}
#canvas{border:1px solid red;}
</style>

<script>
$(function(){

var canvas=document.getElementById("canvas");
var ctx=canvas.getContext("2d");
var canvasOffset=$("#canvas").offset();
var offsetX=canvasOffset.left;
var offsetY=canvasOffset.top;

var img=new Image();
img.onload=function(){
canvas.width=img.width;
canvas.height=img.height;
ctx.drawImage(img,0,0);
}
img.crossOrigin="anonymous";
img.src="https://dl.dropboxusercontent.com/u/139992952/stackoverflow/colorhouse.png";


$("#canvas").click(function(e){
mouseX=parseInt(e.clientX-offsetX);
mouseY=parseInt(e.clientY-offsetY);

// desaturation colors
var imgData=ctx.getImageData(mouseX,mouseY,1,1);
var data=imgData.data;

$("#results").text("Color at "+mouseX+"/"+mouseY+" is rgba("
+data[0]+","+data[1]+","+data[2]+","+data[3]+")");
});

}); // end $(function(){});
</script>

</head>

<body>
<p id="results">Click to get color</p>
<canvas id="canvas" width=300 height=300></canvas>
</body>
</html>

关于javascript - 如何从来自不同域或服务器的图像中获取颜色?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19404178/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com