- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有这个游戏,目标是将球传过迎面而来的带有空隙的矩形。当球的 x 位置落在距球所经过的矩形右侧一定范围内(正或负)时,将记录得分增益。由于我设置的定时器每 10 毫秒循环一次,因此出现了一个问题,因为有时它工作正常;每个通过的矩形都会添加一个点,但有时它甚至没有注册矩形传球,或者它会注册球的 x 值两次落入边缘,从而为用户提供一个矩形传球的两个点。以下是此机制的部分代码:
/*********Keeps track of score and update TextView with score************/
if (rectWhite1.getTheRight() > Math.round(mBallPos.x) - 5 && rectWhite1.getTheRight() < Math.round(mBallPos.x) + 5) {
runOnUiThread(new Runnable() {
@Override
public void run() {
mScoreboard.addPoint();
scoreTextView.setText(mScoreboard.getScore() + "");
}
});
}
if (rectWhite2.getTheRight() > Math.round(mBallPos.x) - mPointMargin && rectWhite2.getTheRight() < Math.round(mBallPos.x) + mPointMargin) {
runOnUiThread(new Runnable() {
@Override
public void run() {
mScoreboard.addPoint();
scoreTextView.setText(mScoreboard.getScore() + "");
}
});
}
if (rectWhite3.getTheRight() > Math.round(mBallPos.x) - mPointMargin && rectWhite3.getTheRight() < Math.round(mBallPos.x) + mPointMargin) {
runOnUiThread(new Runnable() {
@Override
public void run() {
mScoreboard.addPoint();
scoreTextView.setText(mScoreboard.getScore() + "");
}
});
}
mPointMargin 是设置为成员变量的以像素为单位的数量,它会随着游戏速度的加快而动态变化,以便游戏准确地注册通过。即使我解决了这个错误,它仍然会出错,并且偶尔会漏掉一个分数或一次传球得到双倍分数。无论如何,是否有一种更准确的方式来做到这一点,即添加一次分数并终止该 if 语句,直到再次需要它,或者是否有另一种方法来解决这个问题?
编辑:我破解了这个机制的代码,结果很糟糕。我希望一旦球位于矩形右侧 x 值的右侧,这些点就会开始添加。但是,发生的情况是,一旦矩形通过,这些点就会继续增加数百个。这是我插入的 boolean 方法:
public boolean polylineIntersects(BallView ball, int right) {
boolean intersects = false;
int ballPos1 = 0;
int ballPos2 = 0;
if (ball.getX() < right) {
ballPos1 = Math.round(ball.getX());
}
else if (ball.getX() > right) {
ballPos2 = Math.round(ball.getX());
}
if (ballPos2 > ballPos1) {
intersects = true;
}
else {
intersects = false;
}
return intersects;
}
不管怎样,这是否可以在我不使用实际绘制多段线的情况下工作,因为我找不到检测相交的方法 Polyline (Android Developers)具有指定区域。
编辑 2: 好吧,所以我尝试了这个类(class)并且它有效......它得到了交叉点但是当检查返回真实含义而检查保持真实时它会疯狂地增加分数那些 if 语句是骑自行车发疯,直到它是假的。这是我如何实现您给我的类(class)。
/*Declared Tracker objects in OnCreate*/
//What is below is in OnResume
mTmr3 = new Timer();
mTsk3 = new TimerTask() {
@Override
public void run() {
mTracker.setGateX(rectWhite1.getTheRight());
mTracker2.setGateX(rectWhite2.getTheRight());
mTracker3.setGateX(rectWhite3.getTheRight());
//*********Keeps track of score and update TextView with score*************
if (mTracker.check(mBallView)) {
mediaPlayer1.start();
runOnUiThread(new Runnable() {
@Override
public void run() {
mScoreboard.addPoint();
scoreTextView.setText(mScoreboard.getScore() + "");
}
});
}
if (mTracker2.check(mBallView)) {
mediaPlayer1.start();
runOnUiThread(new Runnable() {
@Override
public void run() {
mScoreboard.addPoint();
scoreTextView.setText(mScoreboard.getScore() + "");
}
});
}
if (mTracker3.check(mBallView)) {
mediaPlayer1.start();
runOnUiThread(new Runnable() {
@Override
public void run() {
mScoreboard.addPoint();
scoreTextView.setText(mScoreboard.getScore() + "");
}
});
}
}
};
mTmr3.schedule(mTsk3, 10, 10);
我将类 Tracker 调整为:
public class Tracker {
private int lastX = Integer.MAX_VALUE;
private int gateX;
public void setGateX(int gateX) {
this.gateX = gateX;
}
public boolean check(BallView ball) {
if (lastX == Integer.MAX_VALUE) {
lastX = Math.round(ball.getX());
}
int currX = Math.round(ball.getX());
return currX == gateX || lastX - gateX < 0 && currX - gateX > 0
|| lastX - gateX > 0 && currX - gateX < 0 ;
}
}
最佳答案
我需要一个答案,这样我才能使用等宽格式。矩形是否有球必须遇到的导出 - 所以它会通过?
--------------
+--+
| | o
| |
+--+ t0
--------------
+--+
| |
o | |
+--+ t1
--------------
球路径是连接 o 的折线。 (这里只是一条直线。)
+--+
| | o
o | |
+--+
与“好”形状相交。该计算可以在 t2 完成,此时球已通过该形状。在 t0 和 t1,只需要保存球的位置,并快速检查球是否仍在形状的上限以下。
所以“好”形状是连接两个间隙“角极”的形状,用 GGGG 标记。
+--+
| | o
GGGG
o | |
+--+
稍后 根据 polylineIntersects
,BallView
可以让您执行 getX。
public class Tracker {
private int lastX = Integer.MAX_VALUE;
private int gateX;
public Tracker( int gateX ){
this.gateX = gateX;
}
public boolean check( BallView ball ){
if( lastX == Integer.MAX_VALUE ){
lastX = ball.getX();
return;
}
int currX = ball.getX();
return currX == gateX ||
lastX - gateX > 0 && currX - gateX < 0 ||
lastX - gateX < 0 && currX - gateX > 0;
}
需要为前面的每个矩形/间隙创建一个类 Tracker 的对象。然后必须为每个新的 BallView 调用方法检查。一旦它返回 true,得分 +1 并丢弃 Tracker 对象(或添加重新建立原始状态的重置)。
关于java - 加点机制麻烦?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28790652/
这是一个复杂的查询,我希望用一条语句实现它,而不是必须在 PHP 中处理数组值。 要达到预期的输出: User Jobs Total John D. 5 $1245.67 Ma
SELECT B. * , SC.cate_name, ( CASE WHEN special_offer_type = 'Fixed Value' THEN B.price - special_o
关于将 booksleeve 与 protobuf-net 结合使用,我有一些相当基本的问题。现在我已经实现了一个单例类来管理连接,所以我多次重复使用与 recommended 相同的连接。 .现在我
我想要一个客户端加/减系统,用户可以单击加号,值会增加 1,减号,值会减少 1,该值永远不应该低于零,并且应该从 0 开始.有没有办法在 jquery 中简单地做到这一点?所有 jquery 插件都会
我正在使用加号和减号按钮更新我的产品数量,这很有效,但我的问题是因为我在一个容器中有多个产品,它正在更新所有产品的数量。这是代码:
我需要在大小相等的小整数数组上做大量简单的代数运算。这些操作仅包括三种:(i) 添加数组和 (ii) 按元素减去数组,以及 (iii) 比较一个数组中的所有元素是否不小于/大于另一个数组中的对应元素。
我对 javascript 很陌生,但我需要一种 JS 方式来在单击按钮时增加/减少输入字段中的值。我已成功将值设置为显示 0,但当我单击“添加”按钮时,它不会增加。 以下是 html 和 JS 代码
我可以在输入字段中添加/减去一个数字。 但是,我希望结果显示在中而不是在input中字段。 我尝试使用innerHTML自己完成它但无法让它发挥作用。 $(function() { $('.min
我的页面上有一个加号/减号 jquery 选择器。当页面加载或数字达到 1 时,我希望减号按钮变灰以模拟非事件状态。这是我的代码和 fiddle https://jsfiddle.net/pgxvhs
我如何加/减用户输入的十六进制数? 喜欢: basehex = input() sechex = input() sum = hex(basehex - sechex) print(sum) 我得到:
本文实例讲述了python简单实现矩阵的乘,加,转置和逆运算。分享给大家供大家参考,具体如下: 使用python完成矩阵的乘,加,转置和逆: ?
我输入的一些文本包括几个上下箭头(↑ 和 ↓),以及一个加号/减号 (±)。 这些特殊字符以 HTML ASCII 输入:↑ ↓ ±。在 POST 上,HTML 在保存到 MySQL 表之前使用 ht
我正在尝试配置 Live Gamer Portable 2 Plus 的输出引脚以降低帧速率。通过 GraphStudioNext,我可以通过捕获引脚访问配置并更改帧速率。 但是,当我通过 API 在
我正在尝试使用批处理文件创建任意时间。我试图从我的代码中减去设置值(例如1天,1个月和2000年),以显示系统时间减去前面所述的设置值。对于小时和分钟,我要减去10小时和10分钟(在代码中显示为不同的
我想建立一个 5 位向上/向下计数器。当我能让模拟工作时,我会更乐意购买零碎的东西来构建它。到目前为止,我使用的是 ATmega8,但坦率地说,只要组件相当便宜,任何解决方案都适合我。 我在网上找到了
使用 ng-repeat 时在数字输入字段上添加加/减切换的最佳方法是什么 我这样试过,但没用: - + vm.plus = f
我正在尝试弄清楚如何将 UNION 与相同的 JOIN 一起使用,而不是陷入 #2014 - 命令不同步。 我创建了四个简单的表格并为它们编写了简化的代码。主要想法是获得名字中带有“最佳”字样的每把剑
这个问题已经有答案了: Is floating point math broken? (33 个回答) 已关闭 9 年前。 我有一个简单的函数,应该生成 1000 个不同的元素: var start
我目前正在编写一个响应式设计,我正处于移动导航折叠的地步。 为此,我创建了两个 div 和一个 ul。 ul 包含我的 nav 元素,而 div 将显示移动设备和平板电脑下拉菜单的导航图像。 HTML
我为 woocommerce 单个产品页面创建了一个加/减数量按钮。创建了一个新的数量-input.php " min="" max="" name="" value="" ti
我是一名优秀的程序员,十分优秀!