交互消息式IMessage扩展开发记录

IMessage扩展简介

iOS10新加入的基于iMessage的应用扩展,可以丰富发送消息的内容。(分享表情、图片、文字、视频、动态消息;一起完成任务或游戏。)

简单的将发送的数据内型分为三种:

1.贴纸Stickers;

2.交互消息Interactive Messages; (本文介绍此种)

3.图片,音视频,文本,链接等;

两种显示模式:Compact和Expanded。

Compact(收缩)模式不能访问键盘和相机,不能使用横向滑动,横向滑动操作会由系统捕获;但可以访问输入框。

Expanded(展开)模式不能访问用户输入框;但是可以访问键盘、相机,并且可以使用横向滑动操作。

新建IMessage扩展

xcode新建

打开xcode :File->New->Target 然后在右侧输入框输入IMessage->点击IMessage Extension

podfile

podfile里面加入IMessage需要依赖的库,下面是一个例子,这里我提取了跟主应用公共依赖的库到函数commonPod,需要注意的是有用了UIAPPlication的库在IMessage里面可能导致崩溃,因为很多直接获取这个函数的都会返回空(因为是扩展)

lua 复制代码
platform :ios, '14.0'
def commonPod
    pod "YYKit"
    pod 'SnapKit'
    pod 'SwiftyJSON'
end

target 'TestIM' do
  # Comment the next line if you don't want to use dynamic frameworks
  use_frameworks!
  commonPod
  
  pod 'LookinServer', :configurations => ['Debug']
  pod 'IQKeyboardManagerSwift'

end

target 'MyIM' do
 use_frameworks!
 
commonPod

end

应用图标

新建项目默认在asset中有这个文件(如下图),但是右侧图标都是空的,需要按照下面图标标的样式,手动将对应文件拖到右边的那个位置。

目录结构

新建的IMessage扩展只有如下文件,主要UI代码是在MessagesViewController上进行显示。

使用IMessage api

MessagesViewController

本类为新建IMessage xcode自动为我们创建的类,他继承MSMessagesAppViewController(然后这个又继承自UIViewController),为主要控制IMessage展示的控制器。

它是如下图所示,框中的部分是收缩状态的vc,需要注意的是 他有一部分是在屏幕之外的,向上手动拖拽扩展的时候下面那块才会露出来。

这个是展开状态的vc:

主要生命周期:

swift 复制代码
    //扩展激活(打开)前
    open func willBecomeActive(with conversation: MSConversation)
    //扩展已被激活(打开)
    open func didBecomeActive(with conversation: MSConversation)

    
    //扩展被关闭前
    open func willResignActive(with conversation: MSConversation)

    
   //扩展被关闭
    open func didResignActive(with conversation: MSConversation)
    
    //vc将要收起或者展开 初始化的时候不会调用,只在状态切换时调用。在松手的时候会调用
     @available(iOS 10.0, *)
    open func willTransition(to presentationStyle: MSMessagesAppPresentationStyle)

    
    //vc完成收起或者展开 初始化的时候不会调用,只在状态切换时调用。
    @available(iOS 10.0, *)
    open func didTransition(to presentationStyle: MSMessagesAppPresentationStyle)

需要注意的是,只要这个ViewController变成不可见,这个扩展就会关闭(例如切换IMessage的其他扩展、切后台等。

MessagesViewController有展开收起状态,对应的,他的属性presentationStyle,会是expanded或者compact

open var presentationStyle: MSMessagesAppPresentationStyle { get }

手动调整扩展展开或收缩的状态切换

swift 复制代码
if isExpand {
            requestPresentationStyle(.expanded)
        }else{
            
            requestPresentationStyle(.compact)
        }

MSConversation

在MessagesViewController中有个属性叫activeConversation,它是MSConversation

,用来操作发送,例如IMessage的输入框里面插入文本或组件,或者直接在IMessage中发送文本或者组件。这个东西在模拟器上用回崩溃。

向IMessage的输入框插入文本(并换行)

swift 复制代码
activeConversation?.insertText("这是一串文本")

向IMessage的输入框插入组件:这里使用了MSMessageTemplateLayout配置样式,并通过发送MSMessage实现

swift 复制代码
let layout = MSMessageTemplateLayout()
layout.image = UIImage(named: "iMessage App Icon")
layout.caption = "Ask Al Anything"
let myMessage = MSMessage()
myMessage.layout = layout
activeConversation?.insert(myMessage)

这个组件可以发送到对方手机的IMessage,如果对方装了我们的应用,会在IMessage直接打开扩展并切换到展开状态,否则IMessage的appstore扩展会打开,并展示我们的应用详情页面。

坑点要点

见这篇文章:
iMessage 开发要点 坑点记录

相关推荐
Betelgeuse766 小时前
【Flutter For OpenHarmony】TechHub技术资讯界面开发
flutter·ui·华为·交互·harmonyos
徐同保7 小时前
通过ip访问nginx的服务时,被第一个server重定向了,通过设置default_server解决这个问题
ios·iphone
方见华Richard8 小时前
AGI安全三大方向机构对比清单(2025-2026)
人工智能·经验分享·交互·原型模式·空间计算
铁蛋AI编程实战10 小时前
最新 豆包4.0 实操手册:混合架构部署 + 实时交互 + 动态学习
学习·架构·交互
2501_9159184112 小时前
在 iOS 环境下查看 App 详细信息与文件目录
android·ios·小程序·https·uni-app·iphone·webview
杨超越luckly12 小时前
从传统 GIS 向智能/自动化脚本演进:地铁接驳公交识别的 ArcGIS 与 Python 双路径实践
开发语言·arcgis·php·交互·数据可视化
Betelgeuse7613 小时前
【Flutter For OpenHarmony】 阶段复盘:从单页Demo到模块化App
flutter·ui·华为·交互·harmonyos
2501_9160074713 小时前
没有 Mac 用户如何上架 App Store,IPA生成、证书与描述文件管理、跨平台上传
android·macos·ios·小程序·uni-app·iphone·webview
夏幻灵1 天前
HTTPS全面解析:原理、加密机制与证书体
ios·iphone
方见华Richard1 天前
递归对抗引擎RAE:AGI终极希望与内生安全范式革新,自指认知AI为碳硅共生必然主体
人工智能·交互·学习方法·原型模式·空间计算