ฉันต้องทำให้ iPhone สั่น แต่ไม่รู้จะทำยังไงใน Swift ฉันรู้ว่าใน Objective-C คุณเพียงแค่เขียน:
import AudioToolbox
AudioServicesPlayAlertSound(kSystemSoundID_Vibrate);
แต่นั่นไม่ได้ผลสำหรับฉัน
ฉันต้องทำให้ iPhone สั่น แต่ไม่รู้จะทำยังไงใน Swift ฉันรู้ว่าใน Objective-C คุณเพียงแค่เขียน:
import AudioToolbox
AudioServicesPlayAlertSound(kSystemSoundID_Vibrate);
แต่นั่นไม่ได้ผลสำหรับฉัน
คำตอบ:
ตัวอย่างสั้น ๆ :
import UIKit
import AudioToolbox
class ViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
AudioServicesPlayAlertSound(SystemSoundID(kSystemSoundID_Vibrate))
}
}
โหลดลงในโทรศัพท์ของคุณและมันจะสั่น คุณสามารถวางไว้ในฟังก์ชันหรือ IBAction ได้ตามที่คุณต้องการ
AudioServicesPlayAlertSoundWithCompletion(SystemSoundID(kSystemSoundID_Vibrate)) { }
ตามที่เขียนเอกสารรหัสแอปเปิ้ล:
ฟังก์ชันนี้จะเลิกใช้งานในอนาคต ใช้ AudioServicesPlaySystemSoundWithCompletion แทน
หมายเหตุ:หากการสั่นไม่ทำงาน ตรวจสอบการสั่นคือเปิดใช้งานในเสียงและการตั้งค่าสัมผัส
ใน iOS 10 บน iPhone 7 หรือ 7 Plus ให้ลอง:
let generator = UIImpactFeedbackGenerator(style: .heavy)
generator.impactOccurred()
ประเภทการสั่นสะเทือนอื่น ๆ :
import AudioToolbox
AudioServicesPlaySystemSound(1519) // Actuate "Peek" feedback (weak boom)
AudioServicesPlaySystemSound(1520) // Actuate "Pop" feedback (strong boom)
AudioServicesPlaySystemSound(1521) // Actuate "Nope" feedback (series of three weak booms)
ข้อมูลเพิ่มเติมเกี่ยวกับการสั่นสะเทือน - http://www.mikitamanko.com/blog/2017/01/29/haptic-feedback-with-uifeedbackgenerator/
อัปเดต Swift 4.2
เพียงใส่โค้ดด้านล่างลงในโครงการของคุณ
การใช้
Vibration.success.vibrate()
รหัสแหล่งที่มา
enum Vibration {
case error
case success
case warning
case light
case medium
case heavy
@available(iOS 13.0, *)
case soft
@available(iOS 13.0, *)
case rigid
case selection
case oldSchool
public func vibrate() {
switch self {
case .error:
UINotificationFeedbackGenerator().notificationOccurred(.error)
case .success:
UINotificationFeedbackGenerator().notificationOccurred(.success)
case .warning:
UINotificationFeedbackGenerator().notificationOccurred(.warning)
case .light:
UIImpactFeedbackGenerator(style: .light).impactOccurred()
case .medium:
UIImpactFeedbackGenerator(style: .medium).impactOccurred()
case .heavy:
UIImpactFeedbackGenerator(style: .heavy).impactOccurred()
case .soft:
if #available(iOS 13.0, *) {
UIImpactFeedbackGenerator(style: .soft).impactOccurred()
}
case .rigid:
if #available(iOS 13.0, *) {
UIImpactFeedbackGenerator(style: .rigid).impactOccurred()
}
case .selection:
UISelectionFeedbackGenerator().selectionChanged()
case .oldSchool:
AudioServicesPlaySystemSound(SystemSoundID(kSystemSoundID_Vibrate))
}
}
}
สำหรับiOS 10.0+คุณสามารถลองใช้UIFeedbackGenerator
viewController ด้านบนเพียงแค่แทนที่ตัวควบคุมมุมมองในการทดสอบ "แอปมุมมองเดียว"
import UIKit
class ViewController: UIViewController {
var i = 0
override func viewDidLoad() {
super.viewDidLoad()
let btn = UIButton()
self.view.addSubview(btn)
btn.translatesAutoresizingMaskIntoConstraints = false
btn.widthAnchor.constraint(equalToConstant: 160).isActive = true
btn.heightAnchor.constraint(equalToConstant: 160).isActive = true
btn.centerXAnchor.constraint(equalTo: view.centerXAnchor).isActive = true
btn.centerYAnchor.constraint(equalTo: view.centerYAnchor).isActive = true
btn.setTitle("Tap me!", for: .normal)
btn.setTitleColor(UIColor.red, for: .normal)
btn.addTarget(self, action: #selector(tapped), for: .touchUpInside)
}
@objc func tapped() {
i += 1
print("Running \(i)")
switch i {
case 1:
let generator = UINotificationFeedbackGenerator()
generator.notificationOccurred(.error)
case 2:
let generator = UINotificationFeedbackGenerator()
generator.notificationOccurred(.success)
case 3:
let generator = UINotificationFeedbackGenerator()
generator.notificationOccurred(.warning)
case 4:
let generator = UIImpactFeedbackGenerator(style: .light)
generator.impactOccurred()
case 5:
let generator = UIImpactFeedbackGenerator(style: .medium)
generator.impactOccurred()
case 6:
let generator = UIImpactFeedbackGenerator(style: .heavy)
generator.impactOccurred()
default:
let generator = UISelectionFeedbackGenerator()
generator.selectionChanged()
i = 0
}
}
}
เราสามารถทำได้ใน Xcode7.1
import UIKit
import AudioToolbox
class ViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
AudioServicesPlayAlertSound(kSystemSoundID_Vibrate)
}
}
Swift 4.2, 5.0
if #available(iOS 10.0, *) {
UIImpactFeedbackGenerator(style: .light).impactOccurred()
}
คุณยังสามารถเลือกรูปแบบอื่น ๆ เช่น
style: .heavy
style: .medium
//Note: soft and rigid available in only iOS 13.0
style: .soft
style: .rigid
คุณสามารถสั่นโทรศัพท์โดยใช้อย่างใดอย่างหนึ่งหรือAudioServices
Haptic Feedback
// AudioServices
AudioServicesPlayAlertSound(SystemSoundID(kSystemSoundID_Vibrate))
// Haptic Feedback
UIImpactFeedbackGenerator(style: .medium).impactOccurred()
ชำระเงินHapticaเฟรมเวิร์กโอเพนซอร์สของฉันมันรองรับทั้งสองHaptic Feedback
อย่างAudioServices
และรูปแบบการสั่นที่ไม่เหมือนใคร ทำงานบน Swift 4.2, Xcode 10
import AudioToolbox
extension UIDevice {
static func vibrate() {
AudioServicesPlaySystemSound(kSystemSoundID_Vibrate)
}
}
ตอนนี้คุณสามารถโทรได้UIDevice.vibrate()
ตามต้องการ
UINotificationFeedbackGenerator พร้อมใช้งานจาก iOS 10 และทำงานร่วมกับ Haptic v2 เราสามารถตรวจสอบสิ่งนี้:
let feedbackSupportLevel = UIDevice.current.value(forKey: "_feedbackSupportLevel") as? Int
if #available(iOS 10.0, *), let feedbackSupportLevel = feedbackSupportLevel, feedbackSupportLevel > 1 {
do { // 1
let generator = UIImpactFeedbackGenerator(style: .medium)
generator.impactOccurred()
}
do { // or 2
let generator = UINotificationFeedbackGenerator()
generator.notificationOccurred(.success)
}
} else {
AudioServicesPlayAlertSound(SystemSoundID(kSystemSoundID_Vibrate))
}
AudioServicesPlaySystemSound(SystemSoundID(kSystemSoundID_Vibrate))
AudioServicesPlaySystemSound
AudioServicesPlayAlertSound