- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我使用 Canvas 更改网页上图像的颜色(本例为灰度)。但是,通过使用以下代码,仅更改了最后一张图像。
<!doctype html>
<html>
<head>
<script type="text/javascript" src="http://code.jquery.com/jquery.min.js"></script>
<script>
$(function(){
var theImages = [];
var myImages = [];
var theChanged = [];
theImages = document.getElementsByTagName("img");
theChanged = document.getElementsByTagName("img");
// create a temporary canvas to put the original image
var tempCanvas=document.createElement("canvas");
var tempCtx=tempCanvas.getContext("2d");
for (var i=0; i <theImages.length; i++){
myImages[i] = theImages [i];
tempCtx.drawImage(myImages[i],myImages[i].width,myImages[i].height);
var newImage=new Image();
newImage.onload=function(){
// call function to replace red with green
recolorImage(newImage,i, theChanged);
}
newImage.src= myImages[i].src;
}
function recolorImage(img_to_change, number, img_changed){
var newCanvas = document.createElement('canvas');
var ctx = newCanvas.getContext("2d");
var theWidth = img_to_change.width;
var theHeight = img_to_change.height;
newCanvas.width = theWidth;
newCanvas.height = theHeight;
// draw the image on the temporary canvas
ctx.drawImage(img_to_change, 0, 0, theWidth, theHeight);
// pull the entire image into an array of pixel data
var imageData = ctx.getImageData(0, 0, theWidth, theHeight);
// CHANGE OF THE COLOR PIXELS
for (var y = 0; y < theHeight; y ++) {
for (var x = 0; x < theWidth; x ++) {
offset = ((y*(theWidth*4)) + (x*4));
imageData.data[offset + 0] = Math.round((imageData.data[offset + 0] +imageData.data[offset + 1] +imageData.data[offset + 2] )/3);
imageData.data[offset + 1] = imageData.data[offset + 0];
imageData.data[offset + 2] = imageData.data[offset + 0];
} //for
} //for
// final of the CHANGE OF THE PIXEL COLOR
//------------------------------------------------------------------------------------------------------------------
// put the altered data back on the canvas
ctx.putImageData(imageData,0,0);
// put the re-colored image back on the image
var finalImag = img_changed[number-1];
finalImag.src = newCanvas.toDataURL();
}
}); // end $(function(){});
</script>
<body>
<p>First Image</p>
<img src="imagens_250x180/rosa.jpg" name="image0" width=250 height=180 ><br/>
<p>Second Image</p>
<img src="imagens_250x180/ricardina.jpg" name="image1" width=250 height=180 >
<p>Third Image</p>
<img src="imagens_250x180/manaus.jpg" name="image2" width=250 height=180 >
</body>
</html>
最佳答案
我不太理解您的代码所做的一切,所以我重写了很多代码,以便我理解它并使其发挥作用。您或许可以以此为起点,然后重写成您更容易理解的内容:
$(function(){
var theImages = document.getElementsByTagName("img");
for (var i=0; i <theImages.length; i++){
var newImage=new Image();
/*
* Store the current index as the new image's id
* since the onload function is async
*/
newImage.id = i;
newImage.onload=function(){
// Retrieve the correct index
var i = this.id;
// Get width and height
var theWidth = theImages[i].width;
var theHeight = theImages[i].height;
// create a temporary canvas to put the original image
var tempCanvas=document.createElement("canvas");
var tempCtx=tempCanvas.getContext("2d");
// Set width and height of the canvas
tempCanvas.width = theWidth;
tempCanvas.height = theHeight;
// Draw the original in a temporary canvas
tempCtx.drawImage(this, 0, 0, theWidth, theHeight);
// pull the entire image into an array of pixel data
var imageData = tempCtx.getImageData(0, 0, theWidth, theHeight);
// CHANGE OF THE COLOR PIXELS
for (var y = 0; y < theHeight; y ++) {
for (var x = 0; x < theWidth; x ++) {
offset = ((y*(theWidth*4)) + (x*4));
imageData.data[offset + 0] = Math.round((imageData.data[offset + 0] +imageData.data[offset + 1] +imageData.data[offset + 2] )/3);
imageData.data[offset + 1] = imageData.data[offset + 0];
imageData.data[offset + 2] = imageData.data[offset + 0];
} //for
} //for
// put the altered data back on the canvas
tempCtx.putImageData(imageData,0,0);
// Set the original image
theImages[i].src = tempCanvas.toDataURL();
}
newImage.src = theImages[i].src;
}
}); // end $(function(){});
关于javascript - Canvas - 更改网页上所有图像的颜色(例如,灰度),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20340158/
我正在阅读 java swing,但在理解它时遇到问题。 Color 是一个类吗? Color[] col= {Color.RED,Color.BLUE}; 这在java中是什么意思? 最佳答案 Is
我正在研究用 python 编写的 pacman 程序。其中一个模块是处理吃 bean 游戏的图形表示。这当然是一些主机颜色。列表如下: GHOST_COLORS = [] ## establishe
本网站:http://pamplonaenglishteacher.com 源代码在这里:https://github.com/Yorkshireman/pamplona_english_teache
我最近将我的手机更新为 Android Marshmallow 并在其上运行了我现有的应用程序,但注意到颜色行为有所不同:将更改应用到 View (可绘制)的背景时,共享相同背景的所有 View (引
所有 X11/w3c 颜色代码在 Android XML 资源文件格式中是什么样的? I know this looks a tad ridiculous as a question, but giv
试图让 ffmpeg 创建音频波形,同时能够控制图像大小、颜色和幅度。我已经尝试过这个(以及许多变体),但它只是返回无与伦比的 "。 ffmpeg -i input -filter_complex "
我很好奇你是否有一些关于 R 中颜色酿造的技巧,对于许多独特的颜色,以某种方式使图表仍然好看。 我需要大量独特的颜色(至少 24 种,可能需要更多,~50 种)用于堆叠区域图(所以不是热图,渐变色不起
我看到的许多 WPF 示例和示例似乎都有硬编码的颜色。这些指南 - http://msdn.microsoft.com/en-us/library/aa350483.aspx建议不要硬编码颜色。在构建
我想更改文件夹的默认蓝色 如何设置? 最佳答案 :hi Directory guifg=#FF0000 ctermfg=red 关于Vim NERDTree 颜色,我们在Stack Overflow上
是否有关于如何将任意字符串哈希为 RGB 颜色值的最佳实践?或者更一般地说:3 个字节。 你问:我什么时候需要这个?这对我来说并不重要,但想象一下任何 GitHub 上的那些管图 network pa
我正在尝试将默认颜色设置为自定义窗口小部件。 这是有问题的代码。 class ReusableCard extends StatelessWidget { ReusableCard({this.
import javax.swing.*; import javax.swing.table.DefaultTableCellRenderer; import javax.swing.table.Ta
我有一个 less 文件来定义一堆颜色/颜色。每个类名都包含相关颜色的名称,例如 .colourOrange{..} 或 .colourBorderOrange{..} 或 navLeftButtOr
我有一个RelativeLayout,我需要一个黑色背景和一个位于其中间的小图像。我使用了这段代码: 其中@drawable/bottom_box_back是: 这样我就可以将图像居中了。但背
我需要设置 浅色 的 JPanel 背景,只是为了不覆盖文本(粗体黑色)。 此刻我有这个: import java.util.Random; .... private Random random =
我正在尝试制作一个自定义文本编辑器,可以更改特定键入单词的字体和颜色。如何更改使用光标突出显示的文本的字体和/或颜色? 我还没有尝试过突出显示部分。我尝试获取整个 hEdit(HWND) 区域并更改字
我想改变我整个应用程序的颜色。 在我的 AndroidManfiest.xml 中,我有正确的代码: 在 values 文件夹中,我有 app_theme.xml: @style/MyAc
是否可以使用 android 数据绑定(bind)从 xml 中引用颜色? 这很好用: android:textColor="@{inputValue == null ? 0xFFFBC02D : 0
有没有办法在 Android 应用程序中设置“空心”颜色? 我的意思是我想要一个带有某种背景的框,而文本实际上会导致背景透明。换句话说,如果整个 View 在蓝色背景上,文本将是蓝色的,如果它是红色的
我用CGContextStrokePath画在白色背景图片中的一条直线上,描边颜色为红色,alpha为1.0画线后,为什么点不是(255, 0, 0),而是(255, 96, 96)为什么不是纯红色?
我是一名优秀的程序员,十分优秀!