如何从图像数组中选择图像并将该图像绘制在画布上
我正在从事的这个项目遇到了问题。这里的代码是每当鼠标在画布上单击时绘制图像。我有一组国旗,我想让用户选择他们选择的任何国旗并将其绘制在画布上。当我单击选项从画布中选择我选择的任何标志时,它只会绘制一个特定的标志。我希望有人帮助我找到一种方法从数组中选择不同的标志并将它们绘制在画布上。
for(var i = 0; i < 254; i++){
flags[i] = loadImage('assets/flags/a' + i + '.png');
}
this.fla = flags[i];
//where was the mouse on the last time draw was called.
//set it to -1 to begin with
var startMouseX = -1;
var startMouseY = -1;
this.draw = function(){
//if moused is pressed draw selected object at mouse locations on the canvas
if(mouseIsPressed){
//checks the size of the stamp object
var starSize = this.starSizeSlider.value();
var starX = mouseX - starSize/2;
var starY = mouseY - starSize/2;
for(var i = 0; i < flags.length; i++){
if(this.selectionToolForOptions.selected()== flags[i]){
image(flags[i], starX, starY, starSize, starSize);
}
else if (this.selectionToolForOptions.selected()=='cloud'){
image(this.flag, starX, starY, starSize, starSize);
}
}
}
}
//when the tool is deselected just show the drawing and and clear the options
this.unselectedTool = function() {
select("#sizeOfControl").html("");
}
//add options to select type of object to be selected and size the objects
this.populateOptions = function() {
this.textProperty = createDiv('Size: ');
this.textProperty.parent('#sizeOfControl');
this.starSizeSlider = createSlider(5,80,10);
this.starSizeSlider.parent("#sizeOfControl");
this.optionTextProperty = createDiv('Options: ');
this.optionTextProperty.parent("#sizeOfControl");
this.selectCountryFlag = createSelect('Star: ');
this.selectionToolForOptions = createSelect();
this.selectionToolForOptions.parent("#sizeOfControl");
for(var i = 0; i < flags.length; i++){
this.selectionToolForOptions.option(flags[i]);
}
}
I have encountered a problem with this project I'm working on. The code here is to draw an image anytime the mouse is clicked on the canvas. I have an array of country flags and I want to let the user select any flag of their choice and draw it on the canvas. When I click on the option to select any flag of my choice from the canvas, it only draws one particular flag. I want someone to help me find a way to select different flags from the array and draw them on the canvas.
for(var i = 0; i < 254; i++){
flags[i] = loadImage('assets/flags/a' + i + '.png');
}
this.fla = flags[i];
//where was the mouse on the last time draw was called.
//set it to -1 to begin with
var startMouseX = -1;
var startMouseY = -1;
this.draw = function(){
//if moused is pressed draw selected object at mouse locations on the canvas
if(mouseIsPressed){
//checks the size of the stamp object
var starSize = this.starSizeSlider.value();
var starX = mouseX - starSize/2;
var starY = mouseY - starSize/2;
for(var i = 0; i < flags.length; i++){
if(this.selectionToolForOptions.selected()== flags[i]){
image(flags[i], starX, starY, starSize, starSize);
}
else if (this.selectionToolForOptions.selected()=='cloud'){
image(this.flag, starX, starY, starSize, starSize);
}
}
}
}
//when the tool is deselected just show the drawing and and clear the options
this.unselectedTool = function() {
select("#sizeOfControl").html("");
}
//add options to select type of object to be selected and size the objects
this.populateOptions = function() {
this.textProperty = createDiv('Size: ');
this.textProperty.parent('#sizeOfControl');
this.starSizeSlider = createSlider(5,80,10);
this.starSizeSlider.parent("#sizeOfControl");
this.optionTextProperty = createDiv('Options: ');
this.optionTextProperty.parent("#sizeOfControl");
this.selectCountryFlag = createSelect('Star: ');
this.selectionToolForOptions = createSelect();
this.selectionToolForOptions.parent("#sizeOfControl");
for(var i = 0; i < flags.length; i++){
this.selectionToolForOptions.option(flags[i]);
}
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
问题似乎是您指定一个对象(
p5.Image
实例)作为您正在创建的选项的名称。选择选项的名称和值都必须是字符串。因为当p5.Image
转换为字符串时,它是"[object Object]"
所有选择选项都是相同的。这是一个简单的工作示例。
The issue appears to be that you're specifying an object (a
p5.Image
instance) as the name of the options you are creating. Both the name and the value for select options must be strings. Because whenp5.Image
is converted to a string it is"[object Object]"
all of your select options are the same.Here's a simple working example.