We are about to switch to a new forum software. Until then we have removed the registration on this forum.
I made an animation in p5 Javascript. This animaiton has a backgroundimage. This Image is displayed perfectly in firefox and all other browsers except Google Chrome.
Can somebody help me?
var canvas;
var backgroundimage;
var type1_Rect = [];
var type1_Rect_amount = screen.width * 0.2;
var type1_Rect_speed = 1;
var type1_Rect_size = 1;
//-----------------------
var type2_Rect = [];
var type2_Rect_amount = screen.width * 0.1;
var type2_Rect_speed = 0.7;
var type2_Rect_size = 2;
var j = 0;
//------------------------
var i = 0;
function windowResized() {
resizeCanvas(window.innerWidth, window.innerHeight);
}
function setup() {
backgroundimage = loadImage("wallpaper/wallpaper.png"); //The Backgroundimage
canvas = createCanvas(window.innerWidth, window.innerHeight);
canvas.position(0, 0);
canvas.style('z-index', '-10');
for (i = 0; i < type1_Rect_amount; i++) {
type1_Rect[i] = {
x: random(0, screen.width),
y: random(0, screen.height),
display: function() {
fill(255);
noStroke();
rect(this.x, this.y, type1_Rect_size, type1_Rect_size);
},
move: function() {
this.y = this.y - type1_Rect_speed;
if(type1_Rect[i].y <= 0) {
type1_Rect[i].y = window.innerHeight;
}
}
}
}
i = 0;
//-------------------------------------
for (j = 0; j < type2_Rect_amount; j++) {
type2_Rect[j] = {
x: random(0, screen.width),
y: random(0, screen.height),
display: function() {
fill(255);
noStroke();
rect(this.x, this.y, type2_Rect_size, type2_Rect_size);
},
move: function() {
this.y = this.y - type2_Rect_speed;
if(type2_Rect[j].y <= 0) {
type2_Rect[j].y = window.innerHeight;
}
}
}
}
j = 0;
//---------------------------------------
}
function draw() {
image(backgroundimage, 0, 0); //Backgroundimage
fill(255);
//text(screen.width, 50, 50);
//text(type1_Rect_amount, 50, 70);
//text(type2_Rect_amount, 50, 90);
while (i < type1_Rect_amount) {
type1_Rect[i].display();
type1_Rect[i].move();
i++;
}
i = 0;
//----------------------------
while (j < type2_Rect_amount) {
type2_Rect[j].display();
type2_Rect[j].move();
j++;
}
j = 0;
//----------------------------
}
Answers
Edit your post (gear icon in the top right corner of your post), select your code and hit ctrl+o to format it. Make sure there is an empty line above and below your code.
Kf
@kfrajer Thank you. Can you help me? :)
https://p5js.org/reference/#/p5/preload
https://p5js.org/reference/#/p5/loadImage
@GoToLoop
When I use the preload function, the page is loading endlessly in Google Chrome.
This code:
is the same code I am using already. The second one also doesn't work.
Host your sketch at the link below so every1 can try it out:
https://OpenProcessing.org/sketch/create
You can upload your image there too. O:-)
@GoToLoop
I made a Sketch at: https://openprocessing.org/ but it doesn't really work at this website.
This is how it looks like in the firefox browser. All the small white pixels are moving up.data:image/s3,"s3://crabby-images/6c69a/6c69af0616a1d64268466fd42db298b2280e335f" alt="p5 p5"
This is how it looks like with a black background:data:image/s3,"s3://crabby-images/eef0c/eef0caab4ebc789e91073944cfd7da85a4c5d52f" alt="p52 p52"
To all people who dont know how to solve the problem: The code works fine. But when you start it locally with google chrome it wont work. So if you put the code on a webserver it should work. I tried it with a hamatchi server and it worked perfektly.
http://chrome-allow-file-access-from-file.com/