1

我一直试图让这个 CollisionBehavior 函数运行。

lazy var collisionDelegate: UICollisionBehaviorDelegate = self

func collisionBehavior(_ behavior: UICollisionBehavior, beganContactFor item1: UIDynamicItem, with item2: UIDynamicItem, at p: CGPoint) {
    print("colliding")
}
func collisionBehavior(_ behavior: UICollisionBehavior, beganContactFor item: UIDynamicItem, withBoundaryIdentifier identifier: NSCopying?, at p: CGPoint) {
    print("colliding")
}

如您所见,我尝试了两种碰撞行为方法。球和块都是动态对象,我将屏幕末端作为边界。所以每次一个方块或“球”撞到另一个方块、桨、球或屏幕末端时,它应该打印“碰撞”,但终端上不会打印任何内容。下面是块、球、桨和边界的代码。

桨:

    func paddle () {
    lastPaddle.removeFromSuperview()
    collider.removeItem(lastPaddle)

    let yPos = CGFloat(bounds.size.height / 6 * 5)
    let width = bounds.size.width / 4
    let height = bounds.size.width / 20
    if !first {xPos = bounds.midX; first = true}

    let paddle = CGRect(x: xPos + width/2, y: yPos + height/2, width: width, height: height)
    let frame = UIView(frame: paddle)
    frame.backgroundColor = UIColor.red()
    addSubview(frame)
    let item: UIDynamicItem = frame

    let dib = UIDynamicItemBehavior()
    animator.addBehavior(dib)
    dib.allowsRotation = false
    dib.isAnchored = true
    dib.elasticity = 0

    dib.addItem(item)
    collider.addItem(item)
    lastPaddle = frame


    //collider.removeBoundary(withIdentifier: "paddle")

    //update()
}

球:

func createBall () {


    xBall = bounds.midX
    yBall = bounds.midY

    let smallRect = CGRect(x: xBall, y: yBall, width: bounds.size.width/12, height: bounds.size.width/12)
    //let lBall = CGPath(ellipseIn: smallRect, transform: nil)
    ball = smallRect
    let frame = UIView(frame: smallRect)
    frame.backgroundColor = UIColor.green()
    addSubview(frame)
    let item: UIDynamicItem = frame
    //collider.elasticity = 100
    gravity.magnitude = 0.5
    gravity.addItem(item)
    collider.addItem(item)
    //let arr = [item]

    animator.addBehavior(ballBehaviour)

    ballBehaviour.elasticity = 1.5

    ballBehaviour.addItem(item)


}

块和屏幕结束(边界):

    func createBlocks () {
    for a in 0..<numberOfRows {
        for b in 0..<numberOfColumns {
            //let view = UIView()
            let x = CGFloat(b) * (bounds.size.width/CGFloat(numberOfColumns))
            let y = CGFloat(a) * (bounds.size.height/CGFloat(numberOfRows))
            let width = bounds.size.width/CGFloat(numberOfColumns)/2
            let height = bounds.size.height/CGFloat(numberOfRows)/8
            let rect = CGRect(x: x + width/2, y: y/3 + height*3, width: width, height: height)
            //print(rect)
            let frame = UIView(frame: rect)
            blocks.append(frame)
            frame.backgroundColor = UIColor.blue()
            addSubview(frame)
            let item: UIDynamicItem = frame
            //gravity.addItem(item)
            collider.addItem(item)

            blockBehaviour.addItem(item)
            animator.addBehavior(blockBehaviour)





        }
    }
    let rectangle = CGRect(x: 0, y: 0, width: bounds.size.width, height: 3/2 * bounds.size.height)
    //print(rectangle)
    let boundary = UIBezierPath(rect: rectangle)
    collider.addBoundary(withIdentifier: "screen", for: boundary)

}

谢谢你的帮助

4

1 回答 1

1

lazy var的行不通。一个对象 ( self) 不会神奇地举起手说“看看我,我是碰撞代表!” 这不是委托的运作方式。

UICollisionBehavior 对象(我实际上在您的代码中的任何地方都没有看到它——它在哪里?)有一个collisionDelegate属性,它必须设置为self.

于 2016-08-12T20:24:14.350 回答