黄色警告:从UITextDocumentProxy到UIKeyInput的条件强制转换始终成功

时间:2015-07-07 07:36:54

标签: ios xcode swift xcode7 ios9

我正在使用键盘,我刚安装了xcode 7 beta 2 然后我收到很多警告。

超过24个黄色错误我认为它会导致键盘崩溃 在xcode 6.4没有错误,没有键盘课程

我发现很难解决错误。

警告:

  

从UITextDocumentProxy到UIKeyInput的条件转换总是成功

func handleBtnPress(sender: UIButton) {
    if let kbd = self.keyboard {
        if let textDocumentProxy = kbd.textDocumentProxy as? UIKeyInput {
            textDocumentProxy.insertText(sender.titleLabel!.text!)
        }

        kbd.hideLongPress()

        if kbd.shiftState == ShiftState.Enabled {
            kbd.shiftState = ShiftState.Disabled
        }

        kbd.setCapsIfNeeded()
    }
}

警告:

  

从UITouch到UITouch的条件演员总是成功

override func touchesEnded(touches: Set<UITouch>, withEvent event: UIEvent?) {
    for obj in touches {
        if let touch = obj as? UITouch {
            let view = self.touchToView[touch]

            let touchPosition = touch.locationInView(self)

            if self.bounds.contains(touchPosition) {
                self.handleControl(view, controlEvent: .TouchUpInside)
            }
            else {
                self.handleControl(view, controlEvent: .TouchCancel)
            }

            self.touchToView[touch] = nil
        }
    }
}

1 个答案:

答案 0 :(得分:2)

这些不是错误,它们只是警告,它们可能不是崩溃的原因,但您可以通过执行以下操作来解决这两个示例:

UITextDocumentProxy协议无论如何都符合UIKeyInput,因此无需将kbd.textDocumentProxy转换为UIKeyInput

您可以在没有任何警告的情况下执行以下操作:

func handleBtnPress(sender: UIButton) {
    if let kbd = self.keyboard {
        kbd.textDocumentProxy.insertText(sender.titleLabel!.text!)
        kbd.hideLongPress()

        if kbd.shiftState == ShiftState.Enabled {
            kbd.shiftState = ShiftState.Disabled
        }

        kbd.setCapsIfNeeded()
    }
}

obj相同,编译器已经知道它是UITouch对象,所以不需要强制转换它,你可以从if let touch = obj as? UITouch语句中取出所有代码:

override func touchesEnded(touches: Set<UITouch>, withEvent event: UIEvent?) {
    for touch in touches {
        let view = self.touchToView[touch]

        let touchPosition = touch.locationInView(self)

        if self.bounds.contains(touchPosition) {
            self.handleControl(view, controlEvent: .TouchUpInside)
        }
        else {
            self.handleControl(view, controlEvent: .TouchCancel)
        }

        self.touchToView[touch] = nil
    }
}

小提示: alt 点击变量以查看其解析的类型:

enter image description here