美文网首页js css html
整合代码:一个简单的交互式弹簧

整合代码:一个简单的交互式弹簧

作者: 大龙10 | 来源:发表于2022-06-19 05:02 被阅读0次

书名:代码本色:用编程模拟自然系统
作者:Daniel Shiffman
译者:周晗彬
ISBN:978-7-115-36947-5
目录

5.17 整合代码:一个简单的交互式弹簧

  • 对于Box2D,手动设置物体的位置会破坏物理模拟。在toxiclibs中并不存在这样的问题。如果要移动粒子的位置,我们可以直接设置它的x坐标和y坐标。但在设置之前,我们最好先调用lock()函数。

  • lock()函数的作用就是将物体锁在某个位置,等同于将Box2D物体的密度设成0。下面我将展示如何临时锁住一个粒子,然后移动它,最后将它解锁,让它继续参与物理模拟。假设你想在鼠标点击时移动一个粒子。

if (mousePressed) {
    p2.lock(); 先锁住粒子,然后设置它的x坐标和y坐标,再对其解锁
    p2.x = mouseX;
    p2.y = mouseY;
    p2.unlock();
}
  • 在下面的示例程序中,我们将所有元素都放在一起,也就是通过弹簧将两个粒子连接在一起。其中的一个粒子被锁定在某个位置,另一个粒子在鼠标拖动时发生移动。注意,本例和示例代码3-11的效果是一样的。

2、示例

代码5-10 用toxiclibs实现简单的弹簧模拟

import toxi.physics2d.*;
import toxi.physics2d.behaviors.*;
import toxi.geom.*;

// Reference to physics world
VerletPhysics2D physics;

Particle p1;
Particle p2;

void setup() {
  size(640,360);

  // Initialize the physics
  physics=new VerletPhysics2D();
  physics.addBehavior(new GravityBehavior(new Vec2D(0,0.5)));

  // Set the world's bounding box
  physics.setWorldBounds(new Rect(0,0,width,height));
  
  // Make two particles
  p1 = new Particle(new Vec2D(width/2,20));
  p2 = new Particle(new Vec2D(width/2+160,20));
  // Lock one in place
  p1.lock();

  // Make a spring connecting both Particles
  VerletSpring2D spring=new VerletSpring2D(p1,p2,160,0.01);

  // Anything we make, we have to add into the physics world
  physics.addParticle(p1);
  physics.addParticle(p2);
  physics.addSpring(spring);
}

void draw() {

  // Update the physics world
  physics.update();

  background(255);

  // Draw a line between the particles
  stroke(0);
  strokeWeight(2);
  line(p1.x,p1.y,p2.x,p2.y);

  // Display the particles
  p1.display();
  p2.display();

  // Move the second one according to the mouse
  if (mousePressed) {
    p2.lock();
    p2.x = mouseX;
    p2.y = mouseY;
    p2.unlock();
  } 
}

Particle.pde

class Particle extends VerletParticle2D {

  Particle(Vec2D loc) {
    super(loc);
  }

  // All we're doing really is adding a display() function to a VerletParticle
  void display() {
    fill(127);
    stroke(0);
    strokeWeight(2);
    ellipse(x,y,32,32);
  }
}

3、运行结果

相关文章

  • 整合代码:一个简单的交互式弹簧

    书名:代码本色:用编程模拟自然系统作者:Daniel Shiffman译者:周晗彬ISBN:978-7-115-3...

  • ReactNative的插件思考

    使用ReactNative的插件,我们可以简单把它理解成两步:1 是原生代码的整合。原生代码的整合,我们通常的做法...

  • 第09章 绘图和可视化

    学习本章代码案例的最简单方法是在Jupyter notebook进行交互式绘图。在Jupyter notebook...

  • BI分析

    BI商业分析数据分析方法分类, 一,商业智能:a可视化,b交互式c数据加工整合建模,d数据透视 二预测分析,a简单...

  • MySQL:MySQL工具以及5.7mysqlbinlog|my

    随便记录点 5.7.22代码 MySQL工具主要分为 交互式和非交互式 交互式就是我们平时用的交互式命令方式 非交...

  • Python基础(3)-第一个Python程序

    3.1-交互式环境: 在交互式环境中,直接输入代码,按回车,就可以得到代码的执行结果。 运行结果: 3.2-运行....

  • Java日记2018-07-09--sbs整合2

    1 整合的过程中,重新学习了mysql;2 根据简单代码,查看如何整合,将mysql连接起来; 整体来看,效率加...

  • Android 控件移动控制

    大部分代码网上找的,参考地址再找太麻烦了,懒得再找了。 设置位置 弹簧动画1 弹簧动画2

  • 使用mvp+rxjava+retrofit加载数据

    将mvp和rxjava和retrofit简单整合的列子,让activity的代码不再那么臃肿,只负责显示数据. 关...

  • Git入门资源

    Try Git_简单的交互式学习Git

网友评论

    本文标题:整合代码:一个简单的交互式弹簧

    本文链接:https://www.haomeiwen.com/subject/pttumrtx.html