processing集训day03

编程英语

load 加载 image 图像 hawthorn 山楂 true 真

false 假 if 如果 distance 距离 collision 碰

图片显示

显示图片步骤:

1、准备好图片

2、定义图片变量

3、载入图片至变量

4、进行图片显示

Processing 所支持的图片格式有很多,常见的有 PNG、JPG 和 GIF。png 格式的图片后缀名为 .png,

它支持透明、半透明、不透明的图片格式;jpg 格式的图片后缀名为 .jpg,它不支持透明的图片格式;

gif 格式的后缀名为 .gif,它支持透明的图片格式,它是几张图合在一起的图像文件

PImage 专门用于定义调用图片变量的数据类型

PImage 变量名称;

loadImage() 用来载入图片

loadImage( "图片名称" )

注意:填写的图片名称是包含图片的后缀名 , 例如:bg.png

字符串类型 (String)

字符串:双引号包裹起来的内容

String 变量名 = " 变量值 ";

image() 用于显示图片

image( 图片变量名,x坐标,y坐标,宽度,高度 )

注意:图片显示的宽度和高度为可选参数,不需要调整可以不写

// 定义背景图片至变量
PImage bg;
// 载入图片至变量
bg = loadImage("bg.png");
// 显示背景图片
image( bg,00 )

关系运算符

关系运算符:用于两个对象的比较

在这里插入图片描述

比较结果有两个值,真和假。

# 布尔类型

布尔类型 (boolean)

布尔类型数据:表示真或假

布尔值:真 true 假 false

Boolean 变量名 = 布尔值;

布尔表达式:用于衡量真或假的表达式

if语句

if 语句:用于一种情况条件判断,如果满足条件则执行代码

if ( 条件 ){
 执行代码
}

注意:条件可以为布尔表达式,也可以为布尔类型的值

示例:

int a = 76;
int b = 36;
if (a>b){
 line(10,20,50,80);
}

在这里插入图片描述

计算距离

dist() 用于计算两点之间的距离

dist(x1,y1,x2,y2);

分别代表第一个点的x坐标和y坐标第二个点的x坐标和y坐标

课堂案例

实现一个程序,要求设置指定的图片背景,然后有个山楂从上往下降落,鼠标控制糖葫芦串,串碰到了山楂,山楂停止降落,变为糖葫芦

在这里插入图片描述

在这里插入图片描述

实现代码:

PImage bg;
//定义山楂图片变量
PImage hawthorn;
//创建变量x存储山楂的x坐标
int x = 600;
//创建变量y存储山楂的y坐标
int y = 0;
//创建变量collision控制是否发生碰撞
Boolean collision = false;
void setup(){
  size(1500,753);
  //载入背景图片至变量
  bg = loadImage("bg.png");
  //载入山楂图片至变量
  hawthorn = loadImage("before.png");
}

void draw(){
  background(0,0,0);
  //进行背景图片的显示
  image(bg, 0, 0 );
  //设置描边颜色为黑色
  stroke(0);
  //设置描边粗细为5
  strokeWeight(5);
  //绘制直线
  //起点坐标:mouseX+100,mouseY-200 
  //终点坐标:mouseX-50,mouseY+100
  line(mouseX + 100, mouseY - 200, mouseX -50, mouseY + 100);
  //进行山楂图片的显示
  image(hawthorn, x, y , 200,200);
  //山楂掉落
  y = y + 2;
  //越界判断
  if (y >753){
    y = 0;
  }
  //计算竹签最上方点到山楂图片中心点距离
  float distance = dist(mouseX+ 100 , mouseY - 200,x+100, y+100);
  //判断竹签最上方点到山楂中心位置的距离小于50,为真修改collision值
  if(distance < 50){
    collision = true;
  }
  //判断是否发生碰撞,为真修改山楂图片和山楂移动方式
  if(collision){
     x = mouseX -30;
     y = mouseY -220;
     hawthorn = loadImage("after.png");
  }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/339863.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

全栈没有那么难!15 分钟搞明白 Express.js

Express 是老牌的 Node.js 框架&#xff0c;以简单和轻量著称&#xff0c;几行代码就可以启动一个 HTTP 服务器。市面上主流的 Node.js 框架&#xff0c;如 Egg.js、Nest.js 等都与 Express 息息相关。 Express 框架使用标准 Node.js 语法&#xff0c;主要由以下 3 个核心部分…

Elasticsearch8使用统一的CA为HTTP层更新证书

官方文档参考&#xff1a; Update certificates with the same CA | Elasticsearch Guide [8.10] | Elastic 使用统一的CA为HTTP层更新证书&#xff0c;包括3部分&#xff1a;在ES集群内某个节点上生成证书&#xff1b;将生成的证书拷贝给集群内其他节点&#xff1b;更新kiban…

大模型相关学习资料整理

1. 核心2框架 1. semantic-kernel【微软】 https://learn.microsoft.com/en-us/semantic-kernel/overview/ 2. LangChain https://www.langchain.asia/ https://python.langchain.com/docs/get_started/introduction 2. 技术点 1. Function Call https://platform.opena…

Dell戴尔XPS 8930笔记本电脑原装Win10系统 恢复出厂预装OEM系统

链接&#xff1a;https://pan.baidu.com/s/1eaTQeX-LnPJwWt3fBJD8lg?pwdajy2 提取码&#xff1a;ajy2 原厂系统自带所有驱动、出厂主题壁纸、系统属性联机支持标志、系统属性专属LOGO标志、Office办公软件、MyDell等预装程序 文件格式&#xff1a;esd/wim/swm 安装方式&am…

11- OpenCV:自定义线性滤波(卷积,卷积边缘)

目录 一、卷积 1、卷积概念 2、卷积如何工作 3、常见算子&#xff08;卷积核 Kenel&#xff09; 4、自定义卷积模糊 5、代码演示 二、卷积边缘 1、卷积边缘问题 2、处理边缘 3、相关的API说明 4、代码演示 一、卷积 1、卷积概念 &#xff08;1&#xff09;在OpenC…

Recommender Systems with Generative Retrieval

TLDR: 本文提出一种新的生成式检索推荐系统范式TIGER。当前基于大规模检索模型的现代推荐系统&#xff0c;一般由两个阶段的流程实现&#xff1a;训练双编码器模型得到在同一空间中query和候选item的embedding&#xff0c;然后通过近似最近邻搜索来检索出给定query的embedding的…

DBA技术栈MongoDB: 数据增改删除

该博文主要介绍mongoDB对文档数据的增加、更新、删除操作。 1.插入数据 以下案例演示了插入单个文档、多个文档、指定_id、指定多个索引以及插入大量文档的情况。在实际使用中&#xff0c;根据需求选择适合的插入方式。 案例1&#xff1a;插入单个文档 db.visitor.insert({…

zxz-uni-data-select插件,表单回显时,无法显示数据,原因是后端返回的数据是字符串,要把这个字符串转成number类型,就能显示了

zxz-uni-data-select插件&#xff0c;uniapp项目&#xff0c;vue3 表单回显时&#xff0c;这个下拉框不能显示数据 解决方法 用Number()方法把字符串转成number string转成number 回显就能显示了

CAM软件行业调研:广泛应用取得越来越大的市场份额

经过多年的推广&#xff0c;CAM技术已经广泛地应用在机械、电子、航天、化工、建筑等行业。近年来&#xff0c;我国CAM技术的开发和应用取得了长足的发展&#xff0c;除对许多国外软件进行了汉化和二次开发以外&#xff0c;还诞生了不少具有自主版权的CAM系统&#xff0c;由于这…

.NetCore Flurl.Http 升级到4.0后 https 无法建立SSL连接

Flurl.Http-3.2.4 升级到 4.0.0 版本后&#xff0c;https请求异常&#xff1a;Call failed. The SSL connection could not be established. 如下图&#xff1a; Flurl.Http-3.2.4版本绕过https的代码&#xff0c;对于 Flurl.Http-4.0.0 版本来说方法不再适用&#xff0c;3.2.…

js实现页面全屏展示

最近做一个网页项目&#xff0c;用户要求可以全屏展示&#xff0c;进入系统后隐藏地址栏&#xff0c;于是乎&#xff0c;经过调研就选择了全屏API&#xff0c;即便如此还是遇到了一些问题&#xff0c;总结一下&#xff0c;写下此篇文章。 全屏模式 获取Element节点&#xff0c…

红日靶场2打点记录

因为之前成功用冰蝎免杀360&#xff0c;把权限反弹到了MSF上&#xff0c;然后MSF把权限反弹到CS上 所以这次咱们走捷径直接通过反序列化漏洞连接&#xff08;就是关掉360&#xff09;因为权限弹来弹去感觉好麻烦 提示 大家如果想要免杀360千万别学我&#xff0c;我是之前免杀3…

【大数据分析与挖掘技术】Mahout推荐算法

目录 一、推荐的定义与评估 &#xff08;一&#xff09;推荐的定义 &#xff08;二&#xff09;推荐的评估 二、Mahout中的常见推荐算法 &#xff08;一&#xff09;基于用户的推荐算法 &#xff08;二&#xff09;基于物品的推荐算法 &#xff08;三&#xff09;基于S…

Linux配置主机名-使用主机名访问服务器

主要需要对Hosts文件进行操作&#xff0c; Hosts是一个没有扩展名的系统文件&#xff0c;可以用记事本等工具打开&#xff0c;其作用就是将一些常用的网址域名与其对应的IP地址建立一个关联“数据库”&#xff0c; 先将自己的主机名设置成有意义&#xff0c;别人好记的样子&a…

CTF-PWN-堆-【chunk extend/overlapping-1】

文章目录 chunk extend/overlappingfastbin与topchunk相邻free时候不会合并unsortedbinchunk中与topchunk相邻的被free时会合并extend向后overlapping先修改header&#xff0c;再free&#xff0c;再malloc先free&#xff0c;再修改header&#xff0c;再malloc extend向前overla…

【UEFI基础】EDK网络框架(TCP4)

TCP4 TCP4协议说明 相比UDP4&#xff0c;TCP4是一种面向连接的通信协议&#xff0c;因此有更好的可靠性。 TCP4的首部格式如下&#xff1a; 各个参数说明如下&#xff1a; 字段长度&#xff08;bit&#xff09;含义Source Port16源端口&#xff0c;标识哪个应用程序发送。D…

如何在 Ubuntu 22.04 上安装 Linux、Apache、MySQL、PHP (LAMP) 堆栈

前些天发现了一个人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;最重要的屌图甚多&#xff0c;忍不住分享一下给大家。点击跳转到网站。 如何在 Ubuntu 22.04 上安装 Linux、Apache、MySQL、PHP (LAMP) 堆栈 介绍 “LAMP”堆栈是一组开源软件&#…

Linux之进程管理篇(1)

初识进程 1.1 进程 进程&#xff1a;是具有独立功能的一次运行过程&#xff0c;是系统进行资源分配和调度的基本单位。Linux创建新进程时会为其指定和一个唯一的号码&#xff0c;即进程号(PID),以此区别不同的进程。进程不是程序&#xff08;程序&#xff1a;执行特定任务的一…

Istio

1、Istio介绍 Istio 是由 Google、IBM 和 Lyft 开源的微服务管理、保护和监控框架。 官网&#xff1a;https://istio.io/latest/zh/ 官方文档&#xff1a;https://istio.io/docs/ 中文官方文档&#xff1a;https://istio.io/zh/docs Github地址&#xff1a;https://github.com…

Kubernetes/k8s之包管理器helm

helm 在没有helm之前&#xff0c;我们要部署一个服务&#xff0c;deployment、service ingress 的作用通过打包的方式。把deployment、service ingress打包在一块&#xff0c;一键式部署服务。类似于yum功能。是官方提供的类似安装仓库的功能&#xff0c;可以实现一键化部署应…