- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在尝试在控制台屏幕上生成随机的等边三角形。
我使用的方法是为三角形创建一个中心点(随机定位),将中心点移动到原点 (0,0),然后从中心创建 3 个点(添加半径(随机数)三角形到每个点的 Y 轴)。然后我旋转 2 个点,一个旋转 120 度,另一个旋转 240 度,形成一个等边三角形,然后在这些点之间画线。然后将点带回与质心相关的原始绘图。
这在过去的大部分时间都有效,我得到了一个等边三角形,但其他时候我并没有完全得到一个等边三角形,我完全不知道为什么。
我正在使用 Brensenham 的线算法在点之间画线。
工作三角形的图像:http://imgur.com/GpF406O
splinter 三角形的图像:http://imgur.com/Oa2BYun
这是绘制三角形坐标的代码:
void Triangle::createVertex(Vertex cent)
{
// angle of 120 in radians
double s120 = sin(2.0943951024);
double c120 = cos(2.0943951024);
// angle of 240 in radians
double s240 = sin(4.1887902048);
double c240 = cos(4.1887902048);
// bringing centroid to the origin and saving old pos to move later on
int x = cent.getX();
int y = cent.getY();
cent.setX(0);
cent.setY(0);
// creating the points all equal distance from the centroid
Vertex v1(cent.getX(), cent.getY() + radius);
Vertex v2(cent.getX(), cent.getY() + radius);
Vertex v3(cent.getX(), cent.getY() + radius);
// rotate points
double newx = v1.getX() * c120 - v1.getY() * s120;
double newy = v1.getY() * c120 + v1.getX() * s120;
double xnew = v2.getX() * c240 - v2.getY() * s240;
double ynew = v2.getY() * c240 + v2.getX() * s240;
// giving the points the actual location in relation the the old pos of the centroid
v1.setX(newx + x);
v1.setY(newy + y);
v2.setX(xnew + x);
v2.setY(ynew + y);
v3.setX(x);
v3.setY(y + radius);
// adding the to a list (list is used in a function to draw the lines)
vertices.push_back(v1);
vertices.push_back(v2);
vertices.push_back(v3);
}
最佳答案
查看两个三角形的图像(并查看线条绘制算法),您将线条绘制为一系列离散像素。这意味着一个顶点必须落在一个像素中(它不能在边界上),就像这个 image .
那么,如果您的顶点落在*像素之间的边界上会怎样?您的画线算法必须决定将顶点放入哪个像素。
查看wikipedia上的算法描述和页面上的 C++ 实现 www.cs.helsinki.fi我看到两个列表实现都使用整数算术**,在这种情况下,考虑到您有谨慎的像素行,这并不是不合理的。这意味着如果您的浮点计算将一个顶点放在下一行像素的整数标签阈值之上,当 floor(从 float 转换为整数)完成时,但另一个顶点低于该阈值,那么这两个顶点将放在不同的行上。
想想 v1.y = 5.00000000000000000001
和 v2.y = 4.9999999999999999999
这导致 v1 被放置在第 5 行,v2 被放置在第 4 行。
这解释了为什么您只是偶尔看到问题发生,您只是偶尔让您的顶点落在这样的边界上。
为了解决一些问题:
在为顶点赋值时修复它,y 值无论如何都是相同的。
给出:
v1.getX() = v2.getX() = 0 (defined by your code)
v1.getY() = v2.getY() = radius (defined by your code)
cos(120 degrees) = cos(240 degrees) ('tis true)
这会将您的两个 y 值减少为
double newy = v1.getY() * c120
double ynew = v1.getY() * c120
因此:
v1.setY(newy + y);
v2.setY(newy + y);
如果您编写了自己的 Brensenham 算法实现,您可以在该代码中添加一个检查以确保您的顶点处于相同的高度,但是由于端点的高度,这似乎是放置这种检查的一个非常糟糕的地方特定于您的问题,而不是笼统地画线。
**该算法不限于整数运算,但我怀疑考虑到您的问题的不规则性和算法的呈现方式,以及您对图像中的行使用谨慎字符的事实整数算术是个问题。
关于c++ - 有时等边有时不等边的三角形?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36364941/
SDL3 提供了 SDL_RenderGeometry 函数绘制几何图形,用法和 OpenGL 差不多,先定义顶点数据,然后根据顶点数据绘制几何图形。 绘制三角形的代码如下: std::array
我想在图像上使用三角形类型按钮,但我无法执行此操作... 如何做到这一点? 最佳答案 这个project可以帮你。您可以自定义 UIButton 的形状。 关于iphone - 定制非矩形按钮 三角形
我一直在尝试找出如何使用 Python 制作彩虹三角螺旋。我可以制作一个方形螺旋,但它不会导入颜色。而且它不使用三角形。 输出应该是什么样子: 我取得的成就: 我的代码: import tur
我正在使用 this 研究三角形检测算法文章。我编写了这段代码,但不幸的是,当三角形之间存在交集时,该方法返回 false。 private boolean checkTriangleCollisio
我在资源文件中找到了几个关于如何在 Android 中绘制三角形的答案。但是我没有找到任何可以解释如何更改三角形旋转的内容。 我找到的例子:
对于编码类(class)中的作业,我应该找到一种方法让 Python 制作星号三角形,如下所示: x xx xxx 但是,无论我用我的代码做什么,我都无法做到这一点。最好的我可以得到的是:
我在绘制两个多边形时遇到问题。我想填充两个三角形,但一个大于第二个。我在 winforms 中使用 UserControl。代码: Point[] DOWN = new Point[] {new Po
如何测试三角形和正方形是否相交? 当我们知道它是正方形而不是矩形时,有什么方法可以优化它吗?此外,正方形是轴对齐的,这样应该可以进一步提升性能? 或者我应该把正方形分成三角形,然后对三角形-三角形相交
我有一个方法是画一个多边形,然后将多边形向右旋转90度,使其原来的顶点现在指向右边。 这是绘制多边形(三角形)的代码,但我不知道如何旋转它。 Point[] points = new Point[3]
我知道有高效的多边形裁剪算法(例如 Maillot、Vatti、Greiner-Hormann)。然而,这些算法适用于任意多边形,尽管它们适合我的情况,但在我看来,对像我这样的简单情况使用这种通用算法
我的问题可能很愚蠢,但我没有找到三角形 strip 使用的好例子: http://i.stack.imgur.com/KL8jk.png 像这样的顶点: A: -0.5f, -0.5f, // Bo
我正在尝试创建一个等边三角形,您可以在 fiddle 中看到它: 我的想法是,我将笔放在 (0, 0) 处,然后在 (20, 11) 处画线,但三角形看起来不正确。 最佳答案 您的三角形已被
通过编写一些逻辑代码,只是无法弄清楚如何以所需的形式获得 01 三角形的输出,三角形确实打印出来,但不是根据要求的输出。 import java.util.Scanner; import java
我一直在尝试制作一个简单的 pygame 程序来检查光标是否在三角形内部或外部。我通过找到较大三角形的面积,然后从鼠标位置到所有三个点制作三个内部三角形并找到它们的面积来完成此操作。 根据我的理解,如
我有一个方法 drawTriangle,它在 JAVA 中的 OpenGL 程序的 display() 方法中被引用。 public void drawTriangle(GL gl, int x1,
我正在尝试用 C++ 创建一个程序,该程序将数字的三角形模式放入二维数组中。 示例: 1 3 4 5 9 2 9 4 6 1 顶行是一个数字(整数),三角形的每一行比它上面的行多一
所以我最近一直在尝试学习 OpenGL,遵循了几个文本和视频教程。 我无法绘制三角形,我已经双重和三次检查我是否以正确的顺序执行了所有必要的步骤,但我显然遗漏了一些东西 在添加一些代码之前,我应该声明
我遇到了一个用递归绘制谢尔宾斯基三角形的程序。我如何解释这段代码是调用 sierpinski1 直到 n == 0,然后只绘制 3 个小三角形(每次调用一个三角形),因为 n == 0 是绘制某些东西
我有一个需要 3 个点的函数,我将使用这些点来绘制一个三角形,就好像我在使用 glVertex 函数一样。 但由于我想在避免透视变形的同时对这个三角形进行纹理贴图,我必须对其进行 segmentati
下面的代码应该为三角形添加一个 3d 对象,但我收到错误 Assets/Scripts/MakeTriangle.cs(6,28):错误 CS0120:需要对象引用才能访问非静态成员 `UnityEn
我是一名优秀的程序员,十分优秀!