java输出矩形 qt怎么检测碰撞?
浏览量:1292
时间:2021-04-02 06:36:36
作者:admin
qt怎么检测碰撞?
1. qlabel的边界是一个规则矩形,所以判断两个qlabel是否碰撞实际上就是判断两个矩形是否相交?矩形qrect类有一个成员函数intersects,可以直接判断它是否与另一个矩形相交。
2. 要通过键盘控制qlabel,需要获取键盘事件,在键盘事件函数中移动qlabel,判断是否有碰撞。重写标签父窗口的keypressevent或keyreleaseevent函数。
3. 您可以使用图形视图框架来编写界面。使用这个框架来检测碰撞要容易得多。直接调用函数即可。
一个简单的多矩形碰撞算法,有快于N^2的方法吗?
谢谢。
我无法理解解决问题时“碰撞”的含义。我把它理解为矩形覆盖部分重叠时的碰撞。
让我们首先来看一个简单的一维情况:一条线由若干具有给定端点坐标的线段分散而成。如何判断线段是否相交?
n*logn的算法是标记每个端点所在线段的左端点或右端点,然后按坐标对所有端点进行排序。如果线段a的左端点在线段B的左端点和右端点之间,并且线段a的右端点在线段B的左端点和右端点之外,则线段a和B相交。所以排序遍历可以解决。
补充说明:如果线段a及其左右端点位于线段B的左右端点之间,则线段a位于线段B内部,即包含关系。计算包含关系的复杂性与计算交叉关系的复杂性相同。
因此,在二元平面上,所有矩形都可以首先投影到x轴上,并且可以一维方式判断它们是否在x轴上相交。如果它们在x轴上相交,则可以判断相应矩形的投影线段是否在y轴上相交。如果Y轴和X轴之间发生碰撞,则可以确定两个轴相交。
还可以计算正方形的完全覆盖关系。
复杂性是排序n*logn、遍历n和合成n*logn。
在虫岛有更好的算法吗。
版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。
上一篇
ios挪走主屏 苹果手机屏幕失灵
下一篇
网站制作的结构 它是什么结构