ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

java-在处理中使一条线沿着圆的切线移动

2019-11-21 08:02:07  阅读:410  来源: 互联网

标签:calculus java processing


我有一个点遵循圆的路径,并且在确定的时间,我希望该点“折断”并沿着切线行进.我怎么找到这个?有人告诉我导数是

x = -sin(time)

y = -sin(time)

(不确定我是否理解了所讲内容的“时间”部分),但我不知道如何充分理解这一点.有小费吗?这是我目前所拥有的.

/*
Rotor draws circle for random period of time, then moves
in a straight direction for a random period of time, beginning a 
new circle
*/

Rotor r;
float timer = 0;
boolean freeze = false;

void setup() {
  size(1000, 600);
  smooth();
  noFill();
  frameRate(60);
  background(255);

  timeLimit();
  r = new Rotor(100, 100, random(40, 100));
}

void draw() {
  timer = timer + frameRate/1000;

  if(timer > timeLimit()) {
    timer = 0;
    timeLimit();

    if(freeze == true) { 
      freeze = false;
    } else {
      freeze = true;
    }
  }

  if(!freeze) {
    r.drawRotor(); 
  } else {
    r.holdSteady();
  }
}

float timeLimit() {
  float timeLimit = random(100); 
  return timeLimit;
}

转子类:

class Rotor {

  color c;
  int thickness;
  float xPoint;
  float yPoint;
  float nXPoint;
  float nYPoint;
  float radius;
  float angle = 0;
  float centerX;
  float centerY;
  float pointSpeed = frameRate/100;

  Rotor(float cX, float cY, float rad) {
    c = color(0);
    thickness = 1;

    stroke(c);
    strokeWeight(thickness);

    centerX = cX;
    centerY = cY;
    radius = rad;
  } 

  void drawRotor() {
    angle = angle + pointSpeed;
    xPoint = centerX + cos(angle) * radius;
    yPoint = centerY + sin(angle) * radius;
    ellipse(xPoint, yPoint, thickness, thickness);
    strokeWeight(2);
    ellipse(centerX, centerY, 5, 5);
  }

  void holdSteady() {
    xPoint = -sin(angle);//need tangent of circle
    yPoint = -cos(angle);
    ellipse(xPoint, yPoint, 4, 4);
    //then set new center x and y
  }

  void drawNewRotor(float cX, float cy, float rad) {

  }

}

解决方法:

您可以使用tan()

int f =100;
size(300,300);
stroke(0);
translate(width/2, height/2);
for(int i = 0; i< 360; i++){
    point(cos(radians(i))*f,sin(radians(i))*f);
    point(f,tan(radians(i))*f);
    point(tan(radians(i))*f,f);
    }

标签:calculus,java,processing
来源: https://codeday.me/bug/20191121/2050440.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有