- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我到处都看过,但找不到任何关于如何在 Java 3D 中使球体轨道成为中心点的信息。具体来说,我想让一个球体以恒定的速度围绕原点做圆周运动,并让它永远循环。我猜这些方程式与它有关:
X = originX + sin(angle)*Size;
Y = originY + cos(angle)*Size;
我尝试使用 PositionInterpolator,但它只覆盖 1 个轴,因此不会形成圆形轨道。我还注意到一次只能完成 1 个转换,即轴上的旋转或 PositionInterpolator,如何同时将这两个转换应用于对象?
Planet planet = new Planet(new Color3f(0.2f,0.2f,0.2f),new Vector3f(1.0f,0.0f,-10.0f), 0.2f,1.0f,1.0f, 1.0f);
Sphere planet = new Sphere(planet.radius,planet.pl);
Transform3D tfgPlanet = new Transform3D();
// tfg.setTranslation(planet.position);
tfgplanet.setTranslation(planet.position);
TransformGroup tgm = new TransformGroup(tfgPlanet);
tgm.addChild(planet);
theScene.addChild(tgm);
Transform3D planetRotate = new Transform3D();
int timerotation = 1500;//A slow rotation takes 1.5 seconds.
//The Alpha for rotation
Alpha planetRotationStart = new Alpha(1000,
Alpha.INCREASING_ENABLE,0,0,timerotation,0,0,0,0,0);
//rotate around axis
RotationInterpolator planetrotation = new RotationInterpolator(
planetRotationStart,tgm,
planetRotate,planet.orbitAngle,(float) Math.PI*2);
BoundingSphere bind = new BoundingSphere(new Point3d(0.0,0.0,0.0),Double.MAX_VALUE);
planetrotation.setSchedulingBounds(bind);
tgm.setCapability(TransformGroup.ALLOW_TRANSFORM_WRITE);
tgm.addChild(planetrotation);
Alpha planetOrbit = new Alpha(1000,
Alpha.INCREASING_ENABLE,0,0,timerotation,0,0,0,0,0);
Transform3D axis = new Transform3D();
PositionInterpolator pi = new PositionInterpolator(planetOrbit,tgm,axis,1.0f, 10.0f);
pi.setSchedulingBounds(bind);
tgm.addChild(pi);
//compiles scene
theScene.compile();
//Add everything to the universe.
su.addBranchGraph(theScene);
}
最佳答案
代码一团糟(而且似乎部分代码在发布时被复制了?)。但是关于实际问题:
的确,一个TransformGroup
只能包含一个特定的Transform3D
。虽然可以在单个 Transform3D
中组合多个变换(例如旋转和平移),但这不能很好地与预定义的插值器一起工作。
作为基于场景图的API,Java3D 的整体思想是组装一棵节点“树”,其中每个节点都有特定的用途。
在这种情况下,您的树将包含多个节点:
S Sphere: The planet
|
|
RTG Rotation TransformGroup: Responsible for
| rotating the planet about its y-asis
|
|
TTG Translation TransformGroup: Responsible for
| translating the (rotating) planet away from
| the sun
|
OTG Orbit TransformGroup: Responsible for
| rotating the (translated and rotating) planet
| about the center of the sun
|
Root The root node of your universe
您可以通过提供适当的变量和方法名称来确保代码的结构类似于图形的结构。
有一个绕中心旋转的旋转物体的完整示例:
import java.awt.GraphicsConfiguration;
import javax.media.j3d.Alpha;
import javax.media.j3d.BoundingSphere;
import javax.media.j3d.BranchGroup;
import javax.media.j3d.Canvas3D;
import javax.media.j3d.Node;
import javax.media.j3d.RotationInterpolator;
import javax.media.j3d.Transform3D;
import javax.media.j3d.TransformGroup;
import javax.swing.JFrame;
import javax.swing.SwingUtilities;
import javax.vecmath.Point3d;
import javax.vecmath.Vector3d;
import com.sun.j3d.utils.geometry.ColorCube;
import com.sun.j3d.utils.geometry.Sphere;
import com.sun.j3d.utils.universe.SimpleUniverse;
public class SphereOrbit
{
public static void main(String[] args)
{
System.setProperty("sun.awt.noerasebackground", "true");
SwingUtilities.invokeLater(new Runnable()
{
@Override
public void run()
{
createAndShowGUI();
}
});
}
private static void createAndShowGUI()
{
JFrame frame = new JFrame();
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);;
GraphicsConfiguration config =
SimpleUniverse.getPreferredConfiguration();
Canvas3D canvas = new Canvas3D(config);
frame.getContentPane().add(canvas);
SimpleUniverse simpleUniverse = new SimpleUniverse(canvas);
BranchGroup rootBranchGroup = new BranchGroup();
createContents(rootBranchGroup);
simpleUniverse.addBranchGraph(rootBranchGroup);
Transform3D viewPlatformTransform = new Transform3D();
Transform3D t0 = new Transform3D();
t0.setTranslation(new Vector3d(0,0,10));
Transform3D t1 = new Transform3D();
t1.rotX(Math.toRadians(-30));
viewPlatformTransform.mul(t1, t0);
simpleUniverse.getViewingPlatform().
getViewPlatformTransform().setTransform(viewPlatformTransform);;
frame.setSize(800,800);
frame.setLocationRelativeTo(null);
frame.setVisible(true);
}
private static BoundingSphere boundingSphere =
new BoundingSphere(new Point3d(0.0,0.0,0.0), Double.MAX_VALUE);
// Build the transform group that does the rotation
// of the planet in its local coordinate system
// (This will cause the planet to spin about its own y-axis)
private static TransformGroup createRotationTransformGroup(
int rotationTimeMs)
{
TransformGroup rotationTransformGroup = new TransformGroup();
rotationTransformGroup.setCapability(
TransformGroup.ALLOW_TRANSFORM_WRITE);
Alpha rotationAlpha = new Alpha(-1, rotationTimeMs);
RotationInterpolator rotationInterpolator =
new RotationInterpolator(rotationAlpha, rotationTransformGroup);
rotationInterpolator.setSchedulingBounds(boundingSphere);
rotationTransformGroup.addChild(rotationInterpolator);
return rotationTransformGroup;
}
// Build the transform group that moves the (rotating) planet
// about a certain (fixed) distance, away from the center
private static TransformGroup createTranslatingTransformGroup(
double distanceFromCenter)
{
TransformGroup translationTransformGroup = new TransformGroup();
Transform3D translationTransform = new Transform3D();
translationTransform.setTranslation(
new Vector3d(distanceFromCenter, 0, 0));
translationTransformGroup.setTransform(translationTransform);
return translationTransformGroup;
}
// Build the transform group that orbits the planet. This
// transform group will rotate the (translated and rotating)
// planet around the center
private static TransformGroup createOrbitTransformGroup(int orbitTimeMs)
{
TransformGroup orbitTransformGroup = new TransformGroup();
orbitTransformGroup.setCapability(
TransformGroup.ALLOW_TRANSFORM_WRITE);
Alpha orbitAlpha = new Alpha(-1, orbitTimeMs);
RotationInterpolator orbitInterpolator =
new RotationInterpolator(orbitAlpha, orbitTransformGroup);
orbitInterpolator.setSchedulingBounds(boundingSphere);
orbitTransformGroup.addChild(orbitInterpolator);
return orbitTransformGroup;
}
private static void createContents(BranchGroup rootBranchGroup)
{
// The basic properties of the Planet
int rotationTimeMs = 1500;
double distanceFromCenter = 3;
int orbitTimeMs = 4000;
// The planet (using a color cube here, so that its
// own rotation is visible)
//Node planet = new Sphere(0.2f);
Node planet = new ColorCube(0.2);
TransformGroup rotationTransformGroup =
createRotationTransformGroup(rotationTimeMs);
// Attach the planet to the rotation transform group
rotationTransformGroup.addChild(planet);
TransformGroup translationTransformGroup =
createTranslatingTransformGroup(distanceFromCenter);
// Attach the rotating planet to the translation transform group
translationTransformGroup.addChild(rotationTransformGroup);
TransformGroup orbitTransformGroup =
createOrbitTransformGroup(orbitTimeMs);
// Add the (translated and rotating) planet to the orbitTransformGroup
orbitTransformGroup.addChild(translationTransformGroup);
rootBranchGroup.addChild(orbitTransformGroup);
}
}
(注:仔细观察,你会发现createRotationTransformGroup
方法和createOrbitTransformGroup
方法实际上是在做同样的事情!其中一个是指行星,并且其中一个是指翻译星球。所以对于一个真正的应用程序,它们可以组合成一个方法。我希望在目前的形式中,组装几个的想法节点可能会变得更清晰)
Edit: Extended based on the comments
为了添加另一个围绕现有对象旋转的对象(月亮)(它自己已经在旋转并围绕太阳运行),您必须将一个新分支附加到适当的现有场景图节点。根据上面的(“ASCII-Art”)图像,您必须将此节点附加到“TTG”。新节点本身将包含一个轨道节点、一个平移节点和一个旋转节点(其中包含实际的月球物体)。
如果您打算像这样构建一个完整的太阳系,您可能应该引入适当的实用方法 - 类似于我在这个扩展示例中已经概述的方法:
import java.awt.GraphicsConfiguration;
import javax.media.j3d.Alpha;
import javax.media.j3d.BoundingSphere;
import javax.media.j3d.BranchGroup;
import javax.media.j3d.Canvas3D;
import javax.media.j3d.Node;
import javax.media.j3d.RotationInterpolator;
import javax.media.j3d.Transform3D;
import javax.media.j3d.TransformGroup;
import javax.swing.JFrame;
import javax.swing.SwingUtilities;
import javax.vecmath.Point3d;
import javax.vecmath.Vector3d;
import com.sun.j3d.utils.geometry.ColorCube;
import com.sun.j3d.utils.universe.SimpleUniverse;
public class SphereOrbitExtended
{
public static void main(String[] args)
{
System.setProperty("sun.awt.noerasebackground", "true");
SwingUtilities.invokeLater(new Runnable()
{
@Override
public void run()
{
createAndShowGUI();
}
});
}
private static void createAndShowGUI()
{
JFrame frame = new JFrame();
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);;
GraphicsConfiguration config =
SimpleUniverse.getPreferredConfiguration();
Canvas3D canvas = new Canvas3D(config);
frame.getContentPane().add(canvas);
SimpleUniverse simpleUniverse = new SimpleUniverse(canvas);
BranchGroup rootBranchGroup = new BranchGroup();
createContents(rootBranchGroup);
simpleUniverse.addBranchGraph(rootBranchGroup);
Transform3D viewPlatformTransform = new Transform3D();
Transform3D t0 = new Transform3D();
t0.setTranslation(new Vector3d(0,0,10));
Transform3D t1 = new Transform3D();
t1.rotX(Math.toRadians(-30));
viewPlatformTransform.mul(t1, t0);
simpleUniverse.getViewingPlatform().
getViewPlatformTransform().setTransform(viewPlatformTransform);;
frame.setSize(800,800);
frame.setLocationRelativeTo(null);
frame.setVisible(true);
}
private static BoundingSphere boundingSphere =
new BoundingSphere(new Point3d(0.0,0.0,0.0), Double.MAX_VALUE);
// Build the transform group that does a rotation about the
// y-axis, rotating once in the given time
private static TransformGroup createRotationTransformGroup(
int rotationTimeMs, boolean forward)
{
TransformGroup rotationTransformGroup = new TransformGroup();
rotationTransformGroup.setCapability(
TransformGroup.ALLOW_TRANSFORM_WRITE);
Alpha rotationAlpha = new Alpha(-1, rotationTimeMs);
float angle = forward ? (float) (2 * Math.PI) : (float)(-2 * Math.PI);
RotationInterpolator rotationInterpolator =
new RotationInterpolator(rotationAlpha, rotationTransformGroup,
new Transform3D(), 0.0f, angle);
rotationInterpolator.setSchedulingBounds(boundingSphere);
rotationTransformGroup.addChild(rotationInterpolator);
return rotationTransformGroup;
}
// Build the transform group that performs the specified translation
private static TransformGroup createTranslatingTransformGroup(
double dx, double dy, double dz)
{
TransformGroup translationTransformGroup = new TransformGroup();
Transform3D translationTransform = new Transform3D();
translationTransform.setTranslation(
new Vector3d(dx, dy, dz));
translationTransformGroup.setTransform(translationTransform);
return translationTransformGroup;
}
private static void createContents(BranchGroup rootBranchGroup)
{
int orbitTimeMs = 4000;
TransformGroup orbitTransformGroup =
createRotationTransformGroup(orbitTimeMs, true);
rootBranchGroup.addChild(orbitTransformGroup);
double distanceFromCenter = 3;
TransformGroup translationTransformGroup =
createTranslatingTransformGroup(distanceFromCenter, 0, 0);
orbitTransformGroup.addChild(translationTransformGroup);
int rotationTimeMs = 1500;
Node planet = new ColorCube(0.2);
TransformGroup rotationTransformGroup =
createRotationTransformGroup(rotationTimeMs, true);
rotationTransformGroup.addChild(planet);
translationTransformGroup.addChild(rotationTransformGroup);
int moonOrbitTimeMs = 1000;
TransformGroup moonOrbitTransformGroup =
createRotationTransformGroup(moonOrbitTimeMs, false);
translationTransformGroup.addChild(moonOrbitTransformGroup);
double moonDistanceFromPlanet = 0.8;
TransformGroup moonTranslationTransformGroup =
createTranslatingTransformGroup(moonDistanceFromPlanet, 0, 0);
moonOrbitTransformGroup.addChild(moonTranslationTransformGroup);
int moonRotationTimeMs = 500;
Node moon = new ColorCube(0.1);
TransformGroup moonRotationTransformGroup =
createRotationTransformGroup(moonRotationTimeMs, true);
moonRotationTransformGroup.addChild(moon);
moonTranslationTransformGroup.addChild(moonRotationTransformGroup);
}
}
关于Java3D 球体轨道,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30234453/
我想使用 Orbited 进行聊天。我还找到了 Orbited2。有什么不同? Orbited 死了没有?我想用solid solution,不用担心会被关闭或不支持。我还没有找到任何关于 Orbit
我最近开始学习SFML,我有一个问题,如何使第二个物体在轨道上运动,请帮助。 #include using namespace sf; int main() { RenderWindow wi
我正在尝试使用 Tweepy 获取所有带有关键字的推文,但它没有返回某些关键字的任何内容。例如,如果使用 Obama 作为关键字,我会收到很多推文,如果我使用 Arduino,我不会收到任何返回信息,
在我看来,我有一个复选框和一个标签。我正在使用 SLIM,所以代码是 = check_box_tag 'All Products' = label_tag 'All Products' 生成的等效 H
正如倾斜所暗示的那样,我试图弄清楚如何嵌入 soundcloud 文件,以及如何轻松更改嵌入的声音.. 我有一个网站,目前,让用户写一个故事,然后附加一个图像或视频。对于视频,我使用 vimeo 和
我创建了一个在应用程序的实际背景上绘制的 slider 轨道,并且还绘制了 UISlider 拇指图像。我知道如何设置 slider 的缩略图。但如何隐藏 UISlider 轨道呢? 最佳答案 如果你
从 HTTP 链接下载的 Windows Media DRM 轨道是否可以合法渐进播放? 我已经设法在没有 DRM 的情况下做到了这一点,但这里有人告诉我,使用 DRM 是不可能的。这是真的? 如果是
我有一个简单的 vtt 轨道文件编辑器,其中构建的 vtt 文件内容保存在 var vtt 中. 目前我通过保存vtt的内容来添加轨道。到文件,然后将文件读取为 我想省略保存到文件的步骤,直接将变量
我有一个简单的应用程序,用户可以在其中的文本字段中输入内容以获得各种结果。我想要一个功能,如果用户输入某些内容然后关闭浏览器选项卡,下次他们来时,我可以向他们展示他们之前/最近的搜索。即使他们关闭整个
我试图在不同的线程中同时运行 4 个 MP3 轨道。我正在使用 JLayer1.0 MP3 library播放 MP3。鉴于我无法控制线程何时启动,我使用 CountDownLatch 至少让它们同时
我可以在我的 Android 应用程序中播放来自 SoundCloud 的轨道吗?我正在尝试这段代码,但它不起作用: String res = "https://api.soundcloud.com/
我正在使用 Apple Music API 的 recent played endpoint返回最近播放的媒体 Assets 列表。 然后我使用其中之一并在 MPMusicPlayerControll
我正在使用 Foundation Orbit slider 。它工作正常,只是我需要将一些 css(移动标题)应用于页面上的特定 slider 。 如果我使用以下选择器,它会进行更改,唯一的问题是它是
我最难搞清楚如何在 Foundation 的 Orbit slider 中制作两个文本元素和一个按钮。对于这样的初学者问题,我深表歉意,但我是 Foundation 的新手,有些语法让我感到困惑。 这
我需要来自 SoundCloud 的“最流行”或“ HitTest 门的轨道”,但我找不到任何方法来做到这一点。我可以从 http://api.soundcloud.com/tracks?filter
我刚刚从 Rails 3.2 切换到 Rails 4。我正在努力确保我尽可能了解安全问题,并且我现在担心 session 。看起来 Rails 4 已经不再支持除基于 cookie 的 session
我正在开发一个应用程序,用户可以在其中流式传输或下载视频。我使用 ExoPlayer 2.9.6 实现了相同的功能。目前,在播放下载的内容时,当我尝试切换质量时,它仅显示下载的轨道。我知道它的默认行为
有谁知道制作这样的标题的最佳方法 http://i.imgur.com/NOSF0.png ?我试过使用 Firebug 并实现了这个 http://i.imgur.com/cMB3Y.png但是当我
我正在使用 Zurb 轨道 slider :http://www.zurb.com/playground/jquery_image_slider_plugin 我使用以下设置进行幻灯片放映: $(wi
所以我们在这里:http://greeceinsiders.com/VLASIOS/offcanvas/studio.html 我按照说明在页面中放置轨道 slider ,但这个似乎不起作用。我从其他
我是一名优秀的程序员,十分优秀!