【Processing】创意编程零基础学习笔记

news2024/11/29 2:37:41

博客简介

最近出于兴趣爱好,在学习Processing创意编程。此篇博客用来记录我学习Processing创意编程的基础知识,在我学习Processing的过程中,我会持续修改、更新这篇博客。运用Processing写的一些有趣的小项目,会更新在Procesing专栏的其他文章中。

什么是Processing

Processing是一门由Java开发的编程语言,用来生成图片、动画和交互软件的编程语言,专门为电子艺术和视觉交互设计而创建,用于表达数字创意。

下载Processing

前往Processing官网下载

Processing安装和使用

下载好压缩包后,IDE无需我们自己安装,解压得到一个文件夹如下:
在这里插入图片描述
打开这个文件夹,找到processing.exe直接双击就能运行,为了使用方便使用,可以发送processing.exe快捷键到桌面。

IDE界面

Processing编译器的界面非常整洁,方便用户使用。
在这里插入图片描述

左上角的播放键和停止键是最常用的。

在这里插入图片描述

基础知识篇

函数setup和函数draw

setup是启动程序时用到的代码,可以理解为入口函数。draw是程序持续运行的代码,也就是程序的主体部分,比如哪里有图像出现、哪里有颜色变化,就可以将代码写在这个函数里面。

在这里插入图片描述

播放窗口

点击播放键,会出现一个灰色小窗口,就是processing播放界面,它默认大小是100x100像素:
在这里插入图片描述
也可以通过代码设置播放窗口大小。

属性size

用来设置播放窗口大小,比如将播放窗口设置为400x400像素大小:

void setup(){
  size(400,400);
}

void draw(){
  
}

注意命令后有一个英文分号,写完每个命令后都要加英文分号作为结尾,否则会报错。

设置背景色

设置背景色的代码是持续运行的,所以要写在draw函数里面,processing使用的色彩模式是RGB 255模式,RGB 255模式中红绿蓝三种基本色会分别以0-255之间的数字表示,三种基本色可以混合成超过1600万种颜色。
设置背景色的命令是background,

void setup(){
  size(400,400);
}

void draw(){
  background(255,0,0);
}

考虑到很多颜色的RGB值我们是不知道的,processing给我们提供了一个很好用的工具——颜色选择器,在工具——》颜色选择器就能找到,我们可以选择自己喜欢的颜色,然后它会显示颜色的RGB值。

在这里插入图片描述

绘制图形

1.绘制矩形
命令为rect
如图:左上角坐标为(0,0),绘制矩形命令为rect(100,50,100,20),以左上角为参考,表示该矩形在x轴上坐标为100,在y轴上坐标是50,长100,宽20。
在这里插入图片描述
2.绘制椭圆形(或者圆形)
命令是ellipse
如:ellipse(300,200,100,200)
表示这个椭圆圆心x轴坐标是300,y轴坐标是200,椭圆宽是100,高是200。

println()

变量

  • 全局变量
  • 局部变量
//定义一个全局变量
int xpos = 0;

void setup(){
size(800,800);
}

void draw(){
background(255,255,255);
rect(xpos,100,50,50);
// 需求:通过增加xpos的值让小方块运动起来
xpos = xpos + 1;
println(xpos);
}

参数mouseX,mouseY

这两个参数可以让图形跟随鼠标移动。
设置一个矩形:
rect(mouseX,mouseY,50,50)
运行时,这个矩形的位置将会随鼠标变化。

UleadGIFAnimator5.10软件压缩动图。

以上是鼠标交互
下面学习键盘交互

函数keyPressed

当按下任意键盘上一个键时,函数会被执行。
注意P是大写。
函数中可以使用变量key,key是Processing程序中的预制变量,它记录的是我们的按键信息。
示例:运行代码后,随意点击一个按键,矩形将向右移动两个像素。

int xpos = 0;

void setup(){
size(800,800);
}

void draw(){
  background(255,255,255);
  rect(xpos,0,50,50);
}

void keyPressed(){
println(key);
xpos = xpos + 2;
}

在这里插入图片描述

如果想按下特定按键时对象向特定方向移动,比如玩游戏时wasd移动人物那种,需要学习processing中的if条件语句。

if条件语句

在这里插入图片描述

当预制变量(记录按键信息的一个系统自带变量)等于d时,矩形xpos会向右移动2个像素。

void keyPressed(){
  println(key);
  if(key == 'd'){
    xpos = xpos + 2;
  }
}

如何在Processing中加载图片

1.速写本——》打开程序目录
能看见一个.pde文件,这是我们正在编辑的文件。
2.在该文件夹新建一个文件夹,名为data,注意名称一定为英文小写。
3.将想用的图片拷贝到data文件夹下
4.定义全局变量PImage bunny;
5.用image属性将图片加载到屏幕
image有三个参数,第一个是图片,二三是位置参数。
例如:image(bunny,0,0)
表示将图片bunny加载到(0,0)位置。

在这里插入图片描述
可以自定义图片宽度和高度,在image中设置第四个和第五个参数即可。

PImage bunny;

void setup(){
  size(800,800);
  bunny = loadImage("bunny.png");
}

void draw(){
  background(0,255,0);
  image(bunny,0,0,100,100);
}

将兔子的坐标设置为image(bunny,mouseX,mouseY,200,200);,兔子会跟随我们鼠标移动。

属性imageMode(CENTER)

可以将锚点从(0,0)改为鼠标所在位置。

随机数random

random(a,b)可以产生a到b之间的随机数,我们可以使用随机数设置加载图片的大小和出现位置。
1.加载兔子和萝卜图片:
在这里插入图片描述
2.设置加载图片大小随机,出现位置随机
在这里插入图片描述
运行一下,查看效果:随机产生了很多大小不一、位置不一的兔子。
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Speech and Language Processing之RNN

循环神经网络(RNN)是在其网络连接中包含循环的任何网络。也就是说,任何一个单元的值直接或间接依赖于作为输入的早期输出的网络。虽然这种网络很强大,但很难进行推理和训练。然而,在一般的循环网络中,有一些被证明在应用于口语和书…

深入浅析Linux物理内存外碎片化

本文出现的内核代码来自Linux4.19,如果有兴趣,读者可以配合代码阅读本文。 一、Linux物理内存外碎片化概述 什么是Linux物理内存碎片化?Linux物理内存碎片化包括两种: 1.物理内存内碎片:指分配给用户的内存空间中未…

【Linux命令】fdisk 相关分区命令

fdisk 命令既可以对Ubuntu上已有磁盘进行分区,也可以对SD卡进行分区。假设我们要对最新检测到的 /dev/sdb 设备进行分区。 sudo fdisk /dev/sdb 目录 1、 查看分区情况 —— p 2、删除分区 —— d 3、新增分区 —— n 4、修改分区类型 —— t 5、保存之前所有…

DI依赖注入(setter注入、构造器注入、自动装配、集合注入)

文章目录 1 setter注入1.1 环境准备1.2 注入引用数据类型步骤1:声明属性并提供setter方法步骤2:配置文件中进行注入配置步骤3:运行程序 1.3 注入简单数据类型步骤1:声明属性并提供setter方法步骤2:配置文件中进行注入配置步骤3:运行程序 2 构造器注入2.1 环境准备2.2 构造器注入…

统计学02: 二项分布

<~生~信~交~流~与~合~作~请~关~注~公~众~号生信探索> n 次伯努力事件(发生和不发生概率和为1) 发生r次的概率 期望&#xff1a; &#xff0c;方差&#xff1a; using DistributionsdBinomial(4, 0.35);mean(d) 4*0.35var(d) 4*0.35(1-0.35) Example We asked various p…

用Jenkins搭建自动构建服务

Jenkins是BS跨平台构建工具&#xff0c;之前名为Hundson。wiki 【chs en】 最新windows安装包&#xff1a;下载 下文以1.593版本为例&#xff0c;讲述Jenkins的Windows版本的一些要注意的地方 安装 安装路径中不要出现中文或者空格 用户数据相关的目录结构 ├─Jenkins …

精选 100 种最佳 AI 工具大盘点

为了应对对精简流程和数据分析日益增长的需求&#xff0c;整合人工智能工具在多个领域变得至关重要。 本文精选了2023年可用的100种最佳人工智能工具&#xff0c;旨在提高您的生产力、创造力和效率。 以下是 2023 年排名前 100 的人工智能工具&#xff1a; Aidoc&#xff1a;A…

音频格式m4a怎么转换成mp3,高效工具分享

音频格式m4a怎么转换成mp3&#xff1f;因为当我们下载或是保存的音频格式为m4a时&#xff0c;当我们需要在汽车或是其他平台播放时&#xff0c;就要将音频格式m4a转换成mp3。这样做可以提高音频文件的兼容性、便携性和可用性&#xff0c;并且可以减小文件大小以便于共享和传输。…

Android第一代加壳的验证和测试

Android第一代加壳测试&#xff0c;网上有很多文章&#xff0c;本文只是在前人基础上测试和验证。因此&#xff0c;本文的重点在于动手和实践。 第一代加壳技术有三个项目&#xff0c;分别是&#xff1a; 加壳程序。主要是把需要加壳的原程序加密后&#xff0c;放在壳程序中&…

第12章:视图

一、视图 1.常见的数据库对象 ①表table&#xff1a;表是存储数据的逻辑单元&#xff0c;行和列形式存在。列是字段&#xff0c;行是记录。 ②数据字典&#xff1a;系统表&#xff0c;存放数据库相关信息的表。系统表的数据通常是数据库系统维护。 ③约束constraint&#x…

怎样自己开发制作微信小程序?费用多少?

随着移动互联网的深入发展&#xff0c;各行各业都在寻求转型&#xff0c;希望通过线上软件系统来助力传统企业更好的发展&#xff0c;于是各种APP、小程序软件系统层出不穷。微信小程序是诸多软件中最流行的一种&#xff0c;凭借强大的流量基础、随用随走的便捷性和简单易操作的…

【C++】数据结构的恶龙set和map来了~

下一篇AVL树难点中的难点~ 文章目录 前言一、set的介绍二、map的介绍 题目练习总结 前言 1.关联式容器 在初阶阶段&#xff0c;我们已经接触过STL中的部分容器&#xff0c;比如&#xff1a;vector、list、deque、 forward_list(C11)等&#xff0c;这些容器统称为序列式容…

vue3【抛弃vuex,使用pinia】

Pinia Pinia 中文文档 一个全新的用于Vue的状态管理库下一个版本的vuex&#xff0c;也就是vuex5.0vue2 和vue3都支持在vue2中pinia使用vuex的现有接口&#xff0c;所以不能与vuex一起使用相比vuex有更完美的TypeScript支持支持服务器端渲染 Pinia核心概念 Pinia 从使用角度和…

【论文笔记】Learning Latent Dynamics for Planning from Pixels

论文及代码解读&#xff1a;Learning Latent Dynamics for Planning from Pixels 文章目录 论文及代码解读&#xff1a;Learning Latent Dynamics for Planning from Pixels3. Recurrent State Space ModelLatent dynamicsVariational encoderTraining objectiveDeterministic …

Linux系统编程学习 NO.2 ——环境配置和基础指令的学习

操作系统根据使用方式分类 操作系统按照使用类型可分为图形化操作系统和指令操作系统。图形化操作系统的本质其实也是根据指令来操作的。指令更贴近操作系统的底层。而我在学习Linux系统编程时&#xff0c;采用命令行的方式来学习。 补充一个小知识&#xff1a;早期命令行操作…

原装RS罗德与施瓦茨FSW85、FSW50,FSW67信号+频谱分析仪

Rohde & Schwarz FSW85 2Hz至85GHz信号和频谱分析仪 特征 10 kHz 偏移&#xff08;1 GHz 载波&#xff09;时的低相位噪声为 –137 dBc (1 Hz) WCDMA ACLR 测量的 -88 dBc 动态范围&#xff08;带噪声消除&#xff09; 高达 5 GHz 的分析带宽 < 0.4 dB 总测量不确定度高…

投资回报率业内最高!FortiGate在CyberRatings防火墙独立测试中收获近乎完美表现

对于需参考客观产品数据以制定明智采购决策的企业 IT 采购方而言&#xff0c;公正的第三方测试数据不失为一项关键参考。幸运的是&#xff0c;国际第三方安全测评机构CyberRatings始终秉持公平公正的独立测试理念&#xff0c;致力于量化网络安全风险&#xff0c;为多种网络安全…

用gost实现远程端口映射

gost 是一个非常优秀的tunnel. 支持多种形式的端口映射。 本文只介绍远程端口映射方式的tunnel. 远程端口映射的意思就是&#xff0c;将本地端的某个服务的端口A&#xff08;tcp/udp&#xff09;映射到远程的某个端口P上&#xff0c; 用户通过访问远程的端口P来访问本地端的这…

Linux多路转接之poll

文章目录 一、poll的认识二、编写poll方案服务器三、poll方案多路转接的总结 一、poll的认识 多路转接技术是在不断更新进步的&#xff0c;一开始多路转接采用的是select方案&#xff0c;但是select方案存在的缺点比较多&#xff0c;所以在此基础上改进&#xff0c;产生了poll…

怎么缩小照片的kb,压缩照片kb的几种方法

缩小照片的KB大小是我们日常工作生活中遇到的常见问题。虽然听起来十分专业&#xff0c;但其实很简单。照片的KB是指照片文件的大小&#xff0c;通常以“KB”为单位表示。缩小照片的KB就是减小照片文件的大小&#xff0c;以便占用更少的磁盘空间或更快地上传和下载照片。在实际…