- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在编写一个 WPF 应用程序,它使用 Viewport 3D 来显示一个由 6 个不同颜色的面组成的立方体。最后我试图创建一个可旋转的魔方。
我内置了两种围绕立方体旋转相机的方法,一种是使用“WASD”键,另一种是通过拖动鼠标。
相对于 y 轴旋转相机效果很好(所以“水平”)。但是,当尝试相对于 x 轴旋转相机时,它只有在相机尚未水平旋转时才能正常工作。如果是,则立方体似乎总是将同一个面向上旋转,无论它在哪里。
例如,假设我们使用的是标准魔方。白色的脸朝上,蓝色的脸朝前。当相机还没有旋转时,我按下“W”键或向上拖动鼠标,蓝色面朝白色面的方向移动,所以立方体看起来在向上旋转,这就是我想要的。但是,如果我首先水平旋转相机 180 度,这样白色的脸仍然朝上,但前面的脸现在是绿色的脸,我使用“W”键或向上拖动鼠标,旋转仍然是那个蓝色面朝白色面移动,因此立方体看起来像是在向下旋转。
我的猜测是,这与相机旋转时 x 轴保持在同一位置有关,但我不确定如何修复它。任何帮助将不胜感激。
这是我的相机 XAML 代码:
<Viewport3D.Camera>
<PerspectiveCamera
Position = "2, 2, 5"
LookDirection = "-2, -2, -5"
UpDirection = "0, 1, 0"
NearPlaneDistance="1"
FarPlaneDistance="20"
FieldOfView = "80">
<PerspectiveCamera.Transform>
<Transform3DGroup>
<RotateTransform3D>
<!--Take care of x rotation of camera-->
<RotateTransform3D.Rotation>
<AxisAngleRotation3D x:Name="rotateX" Axis="0 1 0 " Angle="0" />
</RotateTransform3D.Rotation>
</RotateTransform3D>
<RotateTransform3D>
<!--Take care of y rotation of camera-->
<RotateTransform3D.Rotation>
<AxisAngleRotation3D x:Name="rotateY" Axis="1 0 0 " Angle="0" />
</RotateTransform3D.Rotation>
</RotateTransform3D>
</Transform3DGroup>
</PerspectiveCamera.Transform>
</PerspectiveCamera>
</Viewport3D.Camera>
这是我在拖动鼠标时旋转相机的代码(CanvasCube 是包含我的 Viewport3D 的 Canvas ):
private void Window_MouseDown(object sender, MouseButtonEventArgs e)
{
this.Cursor = Cursors.Hand;
oldMouseX = e.GetPosition(CanvasCube).X;
oldMouseY = e.GetPosition(CanvasCube).Y;
mousePressed = true;
}
private void Window_MouseMove(object sender, MouseEventArgs e)
{
if (mousePressed)
{
if(e.GetPosition(CanvasCube).X > oldMouseX)
{
rotateX.Angle --;
oldMouseX = e.GetPosition(CanvasCube).X;
}
else if (e.GetPosition(CanvasCube).X < oldMouseX)
{
rotateX.Angle ++;
oldMouseX = e.GetPosition(CanvasCube).X;
}
if (e.GetPosition(CanvasCube).Y > oldMouseY)
{
rotateY.Angle--;
oldMouseY = e.GetPosition(CanvasCube).Y;
}
else if (e.GetPosition(CanvasCube).Y < oldMouseY)
{
rotateY.Angle++;
oldMouseY = e.GetPosition(CanvasCube).Y;
}
}
}
这是我使用“WASD”键旋转相机的代码:
private void Window_KeyDown(object sender, KeyEventArgs e)
{
switch (e.Key)
{
case Key.W:
angleUp();
break;
case Key.S:
angleDown();
break;
case Key.A:
angleRight();
break;
case Key.D:
angleLeft();
break;}}
private void angleUp()
{
rotateY.Angle+=2;
}
private void angleDown()
{
rotateY.Angle-=2;
}
private void angleRight()
{
rotateX.Angle+=2;
}
private void angleLeft()
{
rotateX.Angle-=2;
}
附言我希望问题是这样清楚的。我觉得很难解释。如果没有,我很乐意进一步解释以澄清。
最佳答案
我设法通过改变变换的角度用单个 RotationTransform 做到了这一点。
<RotateTransform3D >
<RotateTransform3D.Rotation>
<AxisAngleRotation3D Axis="{Binding AxisVector}"
Angle="{Binding Rotation}"/>
</RotateTransform3D.Rotation>
</RotateTransform3D>
然后像这样指定轴和角度:
private bool dragging;
private Point dragStart;
private Point dragTotal;
private double rotation;
private Vector3D axis;
private void Viewport3DOnPreviewMouseMove(object sender, MouseEventArgs e)
{
if (!this.dragging) return;
var pos = e.GetPosition(this.Viewport3D);
var x = pos.X - this.dragStart.X;
var y = pos.Y - this.dragStart.Y;
this.Rotation = Math.Sqrt(x * x + y * y);
this.AxisVector = new Vector3D(y, 0, -x);
}
private void Viewport3DOnPreviewMouseLeftButtonDown(object sender, MouseButtonEventArgs e)
{
this.dragging = true;
this.dragStart = e.GetPosition(this.Viewport3D);
this.dragStart.Offset(-this.dragTotal.X, -this.dragTotal.Y);
}
private void Viewport3DOnPreviewMouseLeftButtonUp(object sender, MouseButtonEventArgs e)
{
this.dragging = false;
var dragEnd = e.GetPosition(this.Viewport3D);
this.dragTotal.X = dragEnd.X - this.dragStart.X;
this.dragTotal.Y = dragEnd.Y - this.dragStart.Y;
}
Axis 的长度可变似乎并不重要。
如果您需要更多代码,请告诉我。
关于c# - 3D 立方体绕 x 和 y 轴旋转,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53778858/
我正在编写国际象棋人工智能程序,并且在实现棋子方格表时遇到了问题。由于我只想每边有一张正方形 table ,因此我需要一个函数来翻转保存 x 轴值的一维数组。例如,这个数组: [ 2, 4, 5, 3
在应用程序中,在尝试使用触摸旋转对象时,我注意到一段时间后对象的位置发生了漂移(没有应用任何平移!!)。旋转仅围绕 z 轴,工作正常,但仅在旋转几次后才会发生漂移。 ds 将用于进行翻译(使用上下按钮
我正在尝试构建金字塔并为其设置动画。问题是在围绕 X 轴旋转它之后,我尝试围绕金字塔的高度(Y 轴)旋转它,但我每次都在移动。我基本上尝试了每个 transform-origin 选项,但它不起作用。
我需要绕其 x 轴(或 y 轴)旋转图像。我可以使用 avisynth 轻松创建这样的动画,但现在我需要使用 Python 的 moviepy 模块来实现该效果。我可以使用以下脚本轻松旋转图像,但需要
我有一个图像被分成两个相等的部分。我正在尝试在悬停时围绕 y 轴将图像的右侧部分旋转 -180°(逆时针)。 问题是有时(随机)图像旋转 180°(顺时针)而不是 -180°(逆时针)。这背后的原因可
如何使用CGAffineTransform(或其他)绕其Y轴旋转UIView?例如,我尝试过: self.image.transform = CGAffineTransform(rotationAng
我正在尝试围绕 y 轴旋转查看器。我有一个名为 tranform_eye() 的函数,它将计算 eyex、eyey 和 eyez 的下一个位置更新。 谁能帮我弄清楚如何计算 eyex、eyey 和 e
我无法解决我遇到的一个奇怪的错误,想知道是否有其他人遇到过类似的问题或可以提供解决方案。 我正在使用 javascript 访问 iOS 设备上的陀螺仪,并且对围绕 z 轴的旋转很感兴趣;我想要设备平
Qt 使用 3x3 变换矩阵进行透视变换和仿射变换。如果矩阵的最后一行等于 [0 0 1],则矩阵被认为是仿射的。由于这个原因,x 轴和 y 轴旋转矩阵是“非仿射”和透视失真结果。但还有进一步的影响。
我是一名优秀的程序员,十分优秀!