- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在通过一个小游戏学习 Swift 和 SpriteKit,在游戏中玩家必须保卫军事基地。然而,玩家必须触摸才能发射子弹。但我希望当他触摸屏幕时,火是持续的,而不是每次都点击屏幕以获得一颗子弹。而且,当他停下来触摸屏幕时,火弹就停止了。
我的火弹功能:
func fireBullet () {
let bullet = SKSpriteNode(imageNamed: "Bullet")
bullet.name = "Bullet" //afin de permettre l'arrêt des missiles en cas de gameOver
bullet.setScale(0.5)
bullet.position = CGPoint(x: planet.position.x, y: planet.position.y)
bullet.anchorPoint = CGPoint(x: 0.5, y: 0.5)
bullet.zPosition = 1
bullet.physicsBody = SKPhysicsBody(rectangleOf: bullet.size) // changer le rectangle en forme circulaire
bullet.physicsBody!.affectedByGravity = false
bullet.physicsBody!.categoryBitMask = physicsCategories.bullet
bullet.physicsBody!.collisionBitMask = physicsCategories.none
bullet.physicsBody!.contactTestBitMask = physicsCategories.asteroid
self.addChild(bullet)
let moveBullet = SKAction.moveTo(y: self.size.height + bullet.size.height, duration: 1.0)
let deleteBullet = SKAction.removeFromParent()
let bulletSequence = SKAction.sequence([bulletSound, moveBullet, deleteBullet])
bullet.run(bulletSequence)
}
我在 TouchesBegan 中调用它:
override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) {
if currentGameState == gameState.preGame {
gameStart()
}
else if currentGameState == gameState.inGame {
fireBullet()
}
感谢您的帮助:)
最佳答案
您可以使用 SKAction 在其内部调用 fireAction。
func fireBullet() {
...
let moveBullet = SKAction.moveTo(y: self.size.height + bullet.size.height, duration: 1.0)
let deleteBullet = SKAction.removeFromParent()
let fireCooldown = SKAction.wait(forDuration: 0.5)
let bulletSequence = SKAction.sequence([bulletSound, moveBullet, deleteBullet, fireCooldown])
bullet.run(bulletSequence) {
if currentGameState == gameState.inGame, isTouchingScreen {
fireBullet()
}
// runs actions, wait for 0.5 seconds and trigger a new fireBullet in completion
}
}
对于冷却时间调整,您可以更改 fireCooldown 值,或者如果您不想等待整个操作发生,您可以从序列中删除 fireCooldown 并在完成时单独触发它。IsTouchingScreen 是一个 bool 值,您可以在 TouchesBegan 中将其设置为 true,然后在 TouchesEnded 中将其设置为 false。
关于swift - 如何连续发射子弹,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55703444/
是否可以用按钮替换 ul 元素符号?我知道您可以使用 CSS 更改为图像,但如果我想要一个实际的元素呢? 最佳答案 这不可能如您所问,但您也许可以效仿它: some button textL
我在让元素符号显示在无序列表中时遇到了一些问题。如果我更改 css 以在内部显示元素符号,它们应该向上,但紧挨着文本。我的伙伴想要的是元素符号显示在框架的最左侧,并且在它和文本之间有几个标签值的空间。
我正在使用 the Orbit component of Foundation 5并想知道是否有办法将出现在幻灯片下方的元素符号移动到幻灯片本身的内容区域中。基本上,将元素符号放在图片上方。 有很多
我有一个从 wordpress 帖子生成的 ul li 边栏。客户为每个 LI 的元素符号使用了不同的图像。与其手动添加单独的元素符号,不如从一组(比如说 10 个)选项中进行选择? 正在考虑 Jqu
我有一个带有方向键和 2 个按钮的游戏 handle 。所有这些都是数字的(不是模拟的)。 我有一个处理他们的事件的程序: -(void)gamepadTick:(float)delta {
稍微注释掉后,我发现当我在 JavaScript 中运行此命令时,我的无序列表中的元素符号消失了(每个“页面”都是我的无序列表中的一个元素。): pages[i].style.display = "b
假设我想存储所有子弹,任何人在我的游戏中射击以计算每帧的新位置等。 如果有 10 名玩家,并且每个人的射击速率为每秒 10 次射击,我们可能需要在 10 秒后跟踪 1000 个物体。 我们确实知道,数
这是我所拥有的: import java.awt.Color; import java.awt.Component; import java.awt.Graphics; import java.awt
我正在通过 ant-design (antd) 库开发一个 reactjs 元素。我想在我的元素中使用 Carousel 组件。当我将内容的背景色 - 应显示在轮播内 - 设置为#FFF 时,元素符号
我是一名优秀的程序员,十分优秀!