الأنشطة المباشرة في iOS
تعرض الأنشطة المباشرة (Live Activities) أحدث بيانات تطبيقك على شاشة القفل في iPhone أو iPad وفي الجزيرة الديناميكية (Dynamic Island). تتيح هذه الميزة للمستخدمين رؤية المعلومات المباشرة بلمحة سريعة وتنفيذ إجراءات سريعة تتعلق بالمعلومات المعروضة.
إليك بعض الأمثلة على استخدام الأنشطة المباشرة:
- إظهار حالة الطلب في تطبيق توصيل؛
- توفير عد تنازلي في الوقت الفعلي في تطبيق تدريب؛
- إظهار معلومات التتبع في تطبيق سيارات الأجرة؛
- عرض إحصائيات اللعبة والنتائج الحالية في تطبيق رياضي؛
- توفير توقعات الطقس كل ساعة في تطبيق الطقس.
يمكنك تمكين الأنشطة المباشرة باستخدام Pushwoosh iOS SDK كما هو موضح أدناه. لإدارة الأنشطة المباشرة وتحديث محتواها، استخدم طريقة /updateLiveActivity.
الإعداد
Anchor link toإضافة ملحق واجهة المستخدم (Widget Extension)
Anchor link to- إنشاء هدف جديد
اذهب إلى File > New > Target واختر Widget Extension.

- إعداد ملحق الواجهة المستخدم (Widget Extension) الرجاء إدخال اسم والتأكد من تحديد Include Live Activity والنقر على Finish.

إعداد Info.plist
Anchor link toابحث عن ملف Info.plist في الهدف الأساسي، وأدرج مفتاح “Supports Live Activities”، واضبط قيمته على YES.
<key>NSSupportsLiveActivities</key> <true/>تمكين الأنشطة المباشرة من التطبيق
Anchor link toلتمكين الأنشطة المباشرة، أضف الكود الخاص بها إلى ملحق الواجهة المستخدم الحالي أو أنشئ واحدًا جديدًا إذا لم يكن لدى تطبيقك واحد بالفعل. تستخدم الأنشطة المباشرة وظائف SwiftUI و WidgetKit لواجهة المستخدم الخاصة بها. يعالج ActivityKit دورة حياة كل نشاط مباشر: يتم استخدام واجهة برمجة التطبيقات (API) الخاصة به لطلب وتحديث وإنهاء نشاط مباشر واستلام إشعارات الدفع من ActivityKit. يمكنك معرفة المزيد عن الأنشطة المباشرة في وثائق Apple.
- انتقل إلى ملف ContentView لمشروعك في Xcode وأنشئ زرًا
import SwiftUI
struct ContentView: View { var body: some View { VStack(spacing: 20) {
Button(action: { LiveActivityManager.shared.startActivity() }, label: { Text("Start Live Activity") .foregroundColor(.white) .padding() .background(Color.blue) .cornerRadius(10) }) } .padding() }}
#Preview { ContentView()}
- أنشئ ملف LiveActivityManager.swift لإدارة الأنشطة المباشرة
import Foundationimport ActivityKitimport UIKitimport PushwooshFrameworkimport PushwooshLiveActivities
class LiveActivityManager: NSObject, ObservableObject { public static let shared: LiveActivityManager = LiveActivityManager()
private var currentActivity: Activity<FoodDeliveryAttributes>? = nil
override init() { super.init() }
func startActivity() { guard ActivityAuthorizationInfo().areActivitiesEnabled else { print("You can't start live activity.") return } do { let pushwooshData = PushwooshLiveActivityAttributeData(activityId: "activity_id") let atttribute = FoodDeliveryAttributes(orderNumber: "1234567", pushwoosh: pushwooshData) let initialState = FoodDeliveryAttributes.ContentState( status: "Preparing your meal", estimatedTime: "25 min", emoji: "👨🍳", pushwoosh: nil ) let activity = try Activity<FoodDeliveryAttributes>.request( attributes: atttribute, content: .init(state:initialState , staleDate: nil), pushType: .token ) self.currentActivity = activity
Task { for await pushToken in activity.pushTokenUpdates { let pushTokenString = pushToken.reduce("") { $0 + String(format: "%02x", $1) } print("Activity:\(activity.id) push token: \(pushTokenString)")
// MARK: - Send Push Token to Pushwoosh Pushwoosh.LiveActivities.startLiveActivity( token: pushTokenString, activityId: "activity_id" ) } } } catch { print("Start Activity Error: \(error.localizedDescription)") } }}- هذا كل شيء، الآن نقوم بتشغيل المشروع ونضغط على زر ‘Start Live Activity’. ثم ننتقل إلى شاشة القفل ونرى النشاط المباشر الذي تم إنشاؤه.

بدء نشاط مباشر بإشعار دفع عن بعد
Anchor link to- لبدء نشاط مباشر عبر إشعار دفع عن بعد، تحتاج إلى إرسال الرمز المميز
pushToStartTokenUpdatesإلى Pushwoosh.
func getPushToStartToken() { if #available(iOS 17.2, *) { Task { for await data in Activity<LiveActivityAttributes>.pushToStartTokenUpdates { let token = data.map {String(format: "%02x", $0)}.joined() print("Activity PushToStart Token: \(token)")
// Send `pushToStartTokenUpdates` token to Pushwoosh try await Pushwoosh.LiveActivities.sendPushToStartLiveActivity(token: token) } } }}- بدء نشاط مباشر بإشعار دفع عن بعد
إدارة الأنشطة المباشرة
Anchor link toيوفر Pushwoosh iOS SDK الطرق التالية للعمل مع الأنشطة المباشرة:
// Send Live Activity Push To Start Token to Pushwooshstatic func sendPushToStartLiveActivity(token: String)static func sendPushToStartLiveActivity(token: String, completion: @escaping (Error?) -> Void)
// Start Live Activity Methods with Activity IDstatic func startLiveActivity(token: String, activityId: String)static func startLiveActivity(token: String, activityId: String, completion: @escaping (Error?) -> Void)
// Stop Live Activity Methodsstatic func stopLiveActivity()static func stopLiveActivity(completion: @escaping (Error?) -> Void)
static func stopLiveActivity(activityId: String)static func stopLiveActivity(activityId: String, completion: @escaping (Error?) -> Void)يمكنك أيضًا تحديث الأنشطة المباشرة حسب الشرائح باستخدام معامل Activity ID. عند إنشاء نشاط، تحتاج إلى تمرير معامل Activity ID فريد في الطريقة، والذي سيكون ذا صلة بشريحة مستخدمين معينة.
على سبيل المثال، اشترك N من المستخدمين في نفس الحدث في نشاط مباشر. من الضروري أن يكون معامل Activity ID فريدًا لجميع هؤلاء المستخدمين N.
عند الانتهاء من العمل مع نشاط مباشر، استخدم هذه الطرق:
static func stopLiveActivity()static func stopLiveActivity(completion: @escaping (Error?) -> Void)طريقة Setup()
Anchor link toيبسط Pushwoosh نقل معرفات النشاط عن طريق تقديم دالة PushwooshLiveActivities.setup، التي تتعامل مع دورة حياة النشاط المباشر بأكملها داخل التطبيق. تستمع هذه الدالة تلقائيًا إلى تحديثات الرموز المميزة pushToStart و pushToUpdate. باستخدام هذه الطريقة، لم يعد التطبيق بحاجة إلى تتبع بدء الأنشطة المباشرة يدويًا أو إدارة تحديثات الرموز المميزة لتحديثات النشاط.
نوصي باستخدام هذه الطريقة لأنها تتعامل مع كل إدارة الرموز المميزة من جانبنا، مما يقلل من كمية الكود الذي تحتاج إلى صيانته من جانبك. هذا يبسط التكامل ويضمن تجربة أكثر سلاسة وكفاءة لتطبيقك.
في AppDelegate، تأكد من استيراد PushwooshFramework و PushwooshLiveActivities واستدعاء طريقة setup من وحدة Pushwoosh.LiveActivities.
AppDelegate.swift
if #available(iOS 16.1, *) { Pushwoosh.LiveActivities.setup(FoodDeliveryAttributes.self)}FoodDeliveryAttributes
import WidgetKitimport SwiftUIimport ActivityKitimport PushwooshFrameworkimport PushwooshLiveActivities
struct FoodDeliveryAttributes: PushwooshLiveActivityAttributes { public struct ContentState: PushwooshLiveActivityContentState { var status: String var estimatedTime: String var emoji: String var pushwoosh: PushwooshLiveActivityContentStateData? }
var orderNumber: String var pushwoosh: PushwooshLiveActivityAttributeData}FoodDeliveryAttributes: يتوافق هذا الهيكل مع بروتوكول PushwooshLiveActivityAttributes. يتم استخدامه لتحديد سمات النشاط المباشر داخل التطبيق.
دليل الترحيل
Anchor link toبدءًا من الإصدار 6.8.0 من Pushwoosh iOS SDK، قمنا بتحديث بنية SDK. يتم الآن الوصول إلى طرق الأنشطة المباشرة من خلال وحدة PushwooshLiveActivities.
إذا كنت تستخدم إصدارًا من Pushwoosh iOS SDK أقدم من 6.8.0 وكنت تستدعي الطرق المدرجة أدناه، وقمت بالتحديث إلى الإصدار 6.8.0 أو أحدث، يرجى ملاحظة التغييرات التالية:
static func setup<Attributes: PushwooshLiveActivityAttributes>(_ activityType: Attributes.Type)static func defaultSetup()static func defaultStart(_ activityId: String, attributes: [String: Any], content: [String: Any])الآن، للوصول إلى هذه الطرق، يجب عليك استخدام وحدة LiveActivity.
import PushwooshFrameworkimport PushwooshLiveActivitiesPushwoosh.LiveActivities.setup(FoodDeliveryAttributes.self)Pushwoosh.LiveActivities.defaultSetup()Pushwoosh.LiveActivities.defaultStart("activity_id", attributes: ["key_attribute": "value_attribute"], content: ["key_content": "value_content"])لقد حافظنا أيضًا على دعم الطرق من خلال Pushwoosh.sharedInstance() كما هو موضح أدناه، ولكن يرجى ملاحظة أن هذه الطرق سيتم إيقافها في الإصدارات المستقبلية.
// Send Live Activity Push To Start Token to Pushwooshstatic func sendPushToStartLiveActivity(token: String)static func sendPushToStartLiveActivity(token: String, completion: @escaping (Error?) -> Void)
// Start Live Activity Methods with Activity IDstatic func startLiveActivity(token: String, activityId: String)static func startLiveActivity(token: String, activityId: String, completion: @escaping (Error?) -> Void)
// Stop Live Activity Methodsstatic func stopLiveActivity()static func stopLiveActivity(completion: @escaping (Error?) -> Void)
static func stopLiveActivity(activityId: String)static func stopLiveActivity(activityId: String, completion: @escaping (Error?) -> Void)