p5.js入门教程(4) 鼠标交互

一、鼠标交互常用关键词

p5.js提供了许多鼠标操作用的关键词与函数,常用的有:

mouseIsPressed:关键词,若鼠标按下则为true,反之为false

mouseButton:关键词,用来判断鼠标按下的是哪个键

案例如下:

 

function setup() { 
  createCanvas(400, 400);
} 
function draw() { 
  background(220);
  if (mouseIsPressed) {
    textAlign(CENTER);
    textSize(30);
    if (mouseButton == LEFT)
      text("LEFT",200,height/2);
    if (mouseButton == RIGHT)
      text("RIGHT",200,height/2);
    if (mouseButton == CENTER)
      text("CENTER",200,height/2);
  }
}

当鼠标按下左、中、右键时,分别会在屏幕上显示“LEFT”、“CENTER”、“RIGHT"。

查看效果:

http://alpha.editor.p5js.org/full/BkEcwrdUb

 

二、鼠标交互常用函数

鼠标操作常用函数如下,还有:

mouseClicked():函数,鼠标点击时触发一次
mousePressed():函数,鼠标按下时触发一次
mouseReleased():函数,鼠标松开时触发一次

我们可以用这些函数控制何时在屏幕上显示图形,案例如下:

 

var showEllipse=false;
var showRect=false;
function setup() { 
  createCanvas(400, 400);
} 
function draw() { 
  background(220);
  if (mouseIsPressed){
    ellipse(50, height/2, 50, 50);
  }
  if(showEllipse){
		ellipse(200, height/2, 50, 50);
  }
  if(showRect){
    rectMode(CENTER);
   rect(350,height/2,50,50); 
  }
}
function mouseClicked(){
  showEllipse=!showEllipse;
}

function mousePressed(){
  showRect=true;
}
function mouseReleased(){
  showRect=false;
}

 

查看效果:

http://alpha.editor.p5js.org/full/BkHEY8OUZ

 

三、鼠标拖拽物体

灵活运用以上关键字和函数,可以做出许多功能,这里举一例,用鼠标拖拽物体。

代码如下:

 

var x=200;
var y=200
var r=50;
function setup() { 
  createCanvas(400, 400);
} 

function draw() { 
  background(220);
  if(mouseIsPressed&&dist(mouseX,mouseY,x,y)<r){
  	x=mouseX;
    y=mouseY;
  }
  ellipse(x,y,r,r);
}

 


最终效果:

成品:http://alpha.editor.p5js.org/full/SJ6gbPdLb

源码:https://editor.p5js.org/WestRiverLin/sketches/SJ6gbPdLb

  • 0
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值