- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在学习 java3D 1.5.2 并且已经完成了一些 ColorCube 测试。我完成的最后一个 java3D 小程序是大约 2000 个 ColorCubes 旋转,在它们自己和整个宇宙中转换。立方体生成为变换分支组的叶节点数组
图片:
我的问题是:有时它显示良好,没有任何问题,但有时窗口是白色的,在我调整窗口大小或使其全屏显示之前什么也没有显示。
问题:你能给我一些关于这个问题的提示吗?我没有使用任何 repaint() 或类似的方法。 Java3D 线程正在绘制我假设的整个东西。我怎样才能克服这个绘图更新问题?
这是一个简短的伪代码:
class myclass extends Applet
{
public void init()
{
//some init here
}
public void start()
{
//i make my thread start here
mythread.start();
}
public void stop()
{
//...i make my thread pause here
}
public void destroy()
{
// Here i release the thread
}
public void paint()
{
//nothing here. its empty
}
public class my_thread extends Thread
{
public void run()
{
//here i use the java3D to initialize java3D things
while(working)
{
// here i change 2000 colorcubes' displacement and rotation
}
}
}
}
这里是我提到的 java3D 的一些初始化:
GraphicsConfiguration GC_me=SimpleUniverse.getPreferredConfiguration();
Canvas3D Canvas_me=new Canvas3D(GC_me);
SimpleUniverse Space_me = new SimpleUniverse(Canvas_me);
谢谢。
完整代码如下:
package fiziksel_model;
import java.awt.*;
import java.applet.*;
import javax.media.j3d.*;
import javax.vecmath.*;
import com.sun.j3d.utils.*;
import com.sun.j3d.utils.geometry.ColorCube;
import com.sun.j3d.utils.universe.SimpleUniverse;
public class yabanci extends Applet{
/**
* Version 1
*/
private static final long serialVersionUID = 1L;
public drawer_thread palette=new drawer_thread();
int i;
public void init()
{
System.out.println(" started! ");
}
//Geometry geom;
public void start()
{
System.out.println(" continuing...");
palette.start();
}
public void stop()
{
System.out.println(" stopped! ");
}
public void destroy()
{
System.out.println(" destroyed!");
}
public void paint(Graphics g)
{
System.out.println(" painted! ");// does not print anything.
}
public class drawer_thread extends Thread
{
public void run()
{
Vector3f temp_vect=new Vector3f();
ColorCube color_box=new ColorCube(0.2f);
GraphicsConfiguration GC_me=SimpleUniverse.getPreferredConfiguration();
Canvas3D Canvas_me=new Canvas3D(GC_me);
SimpleUniverse my_space = new SimpleUniverse(Canvas_me);
BranchGroup cube_barrage = new BranchGroup();
Transform3D rotator_element=new Transform3D();
Transform3D temp_rotator=new Transform3D();
cube_barrage.setCapability(TransformGroup.ALLOW_TRANSFORM_WRITE);
cube_barrage.setCapability(TransformGroup.ALLOW_TRANSFORM_READ);
cube_barrage.setCapability(TransformGroup.ALLOW_CHILDREN_READ);
cube_barrage.setCapability(TransformGroup.ALLOW_CHILDREN_WRITE);
setLayout(new BorderLayout());
TransformGroup rotator1=new TransformGroup(rotator_element);
TransformGroup rotator2=new TransformGroup(rotator_element);
TransformGroup rotator3=new TransformGroup(rotator_element);
TransformGroup rotator4=new TransformGroup(rotator_element);
Vector3f translation[]=new Vector3f[4000];
TransformGroup core1[]=new TransformGroup[4000];
TransformGroup core2[]=new TransformGroup[4000];
TransformGroup core3[]=new TransformGroup[4000];
Transform3D core_move1[]=new Transform3D[4000];
Transform3D core_move2[]=new Transform3D[4000];
Transform3D core_move3[]=new Transform3D[4000];
for(int j=0;j<4000;j++)
{
translation[j]=new Vector3f();
core1[j]=new TransformGroup();core2[j]=new TransformGroup();
core_move1[j]=new Transform3D();
core_move2[j]=new Transform3D();
core_move3[j]=new Transform3D();
}
for(int j=0;j<4000;j++)
{
translation[j]=new Vector3f();
translation[j].x=(float) (j/10.0);
translation[j].y=(float)(-0.5+Math.random()*1.0);
translation[j].z=(float)(-0.5+Math.random()*1.0);
core_move1[j].setTranslation(translation[j]);
core_move2[j].setTranslation(translation[j]);
core_move3[j].setTranslation(translation[j]);
core1[j]=new TransformGroup(core_move1[j]);
core2[j]=new TransformGroup(core_move1[j]);
core3[j]=new TransformGroup(core_move1[j]);
core1[j].setCapability(TransformGroup.ALLOW_TRANSFORM_WRITE);
core1[j].setCapability(TransformGroup.ALLOW_TRANSFORM_READ);
core2[j].setCapability(TransformGroup.ALLOW_TRANSFORM_WRITE);
core2[j].setCapability(TransformGroup.ALLOW_TRANSFORM_READ);
core3[j].setCapability(TransformGroup.ALLOW_TRANSFORM_WRITE);
core3[j].setCapability(TransformGroup.ALLOW_TRANSFORM_READ);
}
rotator1.addChild(rotator2);
rotator2.addChild(rotator3);rotator3.addChild(rotator4);
rotator1.setCapability(TransformGroup.ALLOW_TRANSFORM_WRITE);
rotator1.setCapability(TransformGroup.ALLOW_TRANSFORM_READ);
rotator2.setCapability(TransformGroup.ALLOW_TRANSFORM_WRITE);
rotator2.setCapability(TransformGroup.ALLOW_TRANSFORM_READ);
rotator3.setCapability(TransformGroup.ALLOW_TRANSFORM_WRITE);
rotator3.setCapability(TransformGroup.ALLOW_TRANSFORM_READ);
rotator4.setCapability(TransformGroup.ALLOW_TRANSFORM_WRITE);
rotator4.setCapability(TransformGroup.ALLOW_TRANSFORM_READ);
for(int j=0;j<4000;j++)
{
rotator4.addChild(core1[j]);
core1[j].addChild(core2[j]);
core2[j].addChild(core3[j]);
core3[j].addChild(new ColorCube(0.1));
}
cube_barrage.addChild(rotator1);
cube_barrage.compile();
my_space.addBranchGraph(cube_barrage);
add("Center", Canvas_me);
//Canvas_me.validate();
my_space.getViewingPlatform().setNominalViewingTransform();
float ran[]=new float [4000];
float ran2[]=new float [4000];
Vector3f temp_vector=new Vector3f();
for(int j=0;j<4000;j++)
{
ran[j]=(float) Math.random();
ran2[j]=(float) Math.random();
}
for(i=0;i<10000;i++)
{
rotator1.getTransform(temp_rotator);
temp_rotator.setScale(0.1+0.05*Math.abs(Math.sin(i*0.03)));
rotator1.setTransform(temp_rotator);
rotator2.getTransform(temp_rotator);
temp_rotator.rotX(i*0.03);
rotator2.setTransform(temp_rotator);
rotator3.getTransform(temp_rotator);
temp_rotator.rotY(i*0.03);
rotator3.setTransform(temp_rotator);
rotator4.getTransform(temp_rotator);
temp_rotator.rotZ(i*0.03);
rotator4.setTransform(temp_rotator);
for(int j=0;j<4000;j++)
{
core1[j].getTransform(temp_rotator);
temp_rotator.get(temp_vector);
temp_vector.x+=(float) (-0.5+Math.random())*0.02;
temp_vector.y+=(float) (-0.5+Math.random())*0.02;
temp_vector.z+=(float) (-0.5+Math.random())*0.02;
temp_rotator.setTranslation(temp_vector);
core1[j].setTransform(temp_rotator);
core2[j].getTransform(temp_rotator);
temp_rotator.rotZ(i*0.03+0.01*ran[j]*i);
core2[j].setTransform(temp_rotator);
core2[j].getTransform(temp_rotator);
temp_rotator.rotY(i*0.02+0.01*ran2[j]*i);
core2[j].setTransform(temp_rotator);
}
System.out.println(i);
try {
sleep(40);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}}}
感谢您的宝贵时间。
最佳答案
第二次尝试:将以下代码行从您的线程移动到小程序的 init 方法中,以确保它们在事件分派(dispatch)线程 (EDT) 中运行。
private SimpleUniverse my_space = null;
public void init()
{
System.out.println(" started! ");
GraphicsConfiguration GC_me = SimpleUniverse.getPreferredConfiguration();
Canvas3D Canvas_me = new Canvas3D(GC_me);
my_space = new SimpleUniverse(Canvas_me);
setLayout(new BorderLayout());
add("Center", Canvas_me);
}
请保存您的 200 声望,因为我没有注册。我不知道什么时候注册。
关于Java3D 在小程序中绘制空的白色窗口,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12092053/
我学习 SDL 二维编程已有一段时间了,现在我想创建一个结合使用 SDL 和 OpenGL 的程序。我是这样设置的: SDL_Init(SDL_INIT_VIDEO); window = SDL_Cr
尝试查找可在地块中使用的不同类型项目的列表 来自不同样本的投影类型: projection = list(type = "equirectangular") projection = list(typ
我正在尝试使用 Java Graphics API 绘制 GIF,但无法使用下面的代码成功绘制 GIF。仅绘制 GIF 的第一张图像或缩略图,但不播放。 public void paintCompon
我目前正在使用 JFrame 并尝试绘制一个矩形,但我不知道如何执行代码 paint(Graphics g),如何获取 Graphics 对象? package com.raggaer.frame;
这个领域的新手,希望得到一些帮助。 我有一个"Missile.java" 类,我在那里画东西。我想绘制一个 ImageView,我正在使用以下代码: ImageView v = (ImageView)
下面列出了圆形的例子 这是我的 JavaScript 代码。 最佳答案 假设您的 randomColor 是正确的,您只需要: 从 canvas.onclick 中移除 context.clearR
我在绘制和缩放 ImageView 时遇到问题。请帮帮我.. 当我画一些东西然后拖动或缩放图像时 - 绘图保留在原处,如您在屏幕截图中所见。而且我只需要简单地在图片上绘图,并且可以缩放和拖动这张图片。
我们可以在形式之外绘制图像和文本...我的意思是在字面上... 我知道问这个问题很愚蠢但是我们能不能... 最佳答案 您可以通过创建表单并将其 TransparentColor 属性设置为背景色来“作
我在绘制/布局期间收到 3 个对象分配警告 super.onDraw(canvas); canvas.drawColor(Color.WHITE); Paint textPaint = new Pai
我有一个示例时间序列数据框: df = pd.DataFrame({'year':'1990','1991','1992','1993','1994','1995','1996',
我试图想出一种简洁的方法来绘制 R 数据框中所有列的 GridView 。问题是我的数据框中既有离散值又有数值。为简单起见,我们可以使用 R 提供的名为 iris 的示例数据集。我会使用 par(mf
我有一个由 10 列和 50 行组成的 data.frame。我使用 apply 函数逐列计算密度函数。现在我想绘制我一次计算的密度。 换句话说,而不是绘图... plot(den[[1]]) plo
我想知道我们如何才能在第一个和第二个组件之外绘制个人,如下所示: 最佳答案 这可能有效: pc.cr <- princomp(USArrests, cor = TRUE) pairs(pc.cr$lo
我是Pandas和matplotlib的新手,想绘制此DataFrame season won team matches pct_won 0 20
我正在尝试为 distplot 子图编写一个 for 循环。 我有一个包含许多不同长度列的数据框。 (不包括 NaN 值) fig = make_subplots( rows=len(asse
我想创建一个具有密度的 3d 图。 我使用函数 density 首先为特定的 x 值创建一个二维图,然后该函数创建密度并将它们放入 y 变量中。现在我有第二组 x 值并将其再次放入密度函数中,然后我得
全部, 我一直在研究全局所有 MTB 步道的索引。我是 Python 人,所以对于所有涉及的步骤,我都尝试使用 Python 模块。 我能够像这样从 OSM 立交桥 API 中获取关系: from O
我正在使用 e1071 包中的支持向量机对我的数据进行分类,并希望可视化机器实际如何进行分类。但是,在使用 plot.svm 函数时,出现无法解决的错误。 脚本: library("e1071") d
我制作了以下图表,它是使用 xts 对象创建的。 我使用的代码很简单 plot(graphTS1$CCLL, type = "l", las = 2, ylab = "(c)\nCC for I
在绘制状态图时,您如何知道哪些状态放在框中,哪些状态用于转换箭头?我注意到转换也是状态。 我正在查看 this page 上的图 1 : 最佳答案 转换不是状态。转换是将对象从一种状态移动到下一种状态
我是一名优秀的程序员,十分优秀!