UIActivity可以十分方便地将文字、图片等内容进行分享,比如分享到微信、微博、发送邮件、短信等等。我们不仅可以分享内容出来,也可以在自己的App里添加自己的分享按钮或隐藏已有的分享按钮来实现定制的功能。
下面通过继承UIActivity实现定制按钮和功能,通过调用UIActivityViewController来展示分享框。
注意:UIActivityView面板有上下两行,上面一行是分享按钮(为彩色)。下面一行是动作按钮(图片自动变为黑白)。
下面我们分别在上下各添加一个自定义的功能按钮(“微信”“航歌”)作为演示。
效果图如下:
--- ViewController.swift ---
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
import
UIKit
class
ViewController
:
UIViewController
{
override
func
viewDidLoad() {
super
.viewDidLoad()
}
didReceiveMemoryWarning() {
.didReceiveMemoryWarning()
}
//点击按钮弹出分享框
@IBAction
btnClicked(sender:
AnyObject
) {
//准备分享内容,文本图片链接
let
items = [
"航歌"
,
UIImage
(named:
"toSendImage.png"
)!,
NSURL
(fileURLWithPath:
"http://hangge.com"
)]
//新建自定义的分享对象数组
acts = [
WeiXinActivity
(),147)!important">HanggeActivity
()]
//根据分享内容和自定义的分享按钮调用分享视图
actView:
UIActivityViewController
=
(activityItems: items,applicationActivities: acts)
//要排除的分享按钮,不显示在分享框里
actView.excludedActivityTypes = [
UIActivityTypeMail
UIActivityTypecopyToPasteboard
ottom:auto!important; float:none!important; height:auto!important; left:auto!important; line-height:1.5em!important; margin:0px!important; overflow:visible!important; padding:1px 0px!important; position:static!important; right:auto!important; top:auto!important; vertical-align:baseline!important; width:auto!important; font-family:Consolas,
UIActivityTypePrint
UIActivityTypeAssignToContact
UIActivityTypeSavetoCameraRoll
]
//显示分享视图
self
.presentViewController(actView,animated:
true
ottom:auto!important; float:none!important; height:auto!important; left:auto!important; line-height:1.5em!important; margin:0px!important; overflow:visible!important; padding:1px 0px!important; position:static!important; right:auto!important; top:auto!important; vertical-align:baseline!important; width:auto!important; font-family:Consolas,completion:
nil
)
}
}
|
--- HanggeActivity.swift ---
UIActivity
//用于保存传递过来的要分享的数据
var
text:
String
!
url:
!
image:
!
//显示在分享框里的名称
activityTitle() ->
? {
return
"航歌"
}
//分享框的图片
activityImage() ->
? {
return
"swift.png"
)
}
//分享类型,在UIActivityViewController.completionHandler回调里可以用于判断,一般取当前类名
activityType() ->
? {
.
.description()
}
//按钮类型(分享按钮:在第一行,彩色,动作按钮:在第二行,黑白)
class
activityCategory() ->
UIActivityCategory
{
.
Action
}
//是否显示分享按钮,这里一般根据用户是否授权,或分享内容是否正确等来决定是否要隐藏分享按钮
canPerformWithActivityItems(activityItems: [
]) ->
Bool
{
for
item
in
activityItems {
if
is
{
return
true
}
is
{
true
}
{
true
}
}
false
}
//解析分享数据时调用,可以进行一定的处理
prepareWithActivityItems(activityItems: [
]) {
print
(
"prepareWithActivityItems"
)
activityItems {
{
image = item
as
!
UIImage
}
{
text = item
!
String
}
{
url = item
NSURL
}
}
}
//执行分享行为
//这里根据自己的应用做相应的处理
//例如你可以分享到另外的app例如微信分享,也可以保存数据到照片或其他地方,甚至分享到网络
performActivity() {
"performActivity"
)
//具体的执行代码这边先省略
}
//分享时调用
activityViewController() ->
? {
"activityViewController"
)
nil
}
//完成分享后调用
activityDidFinish(completed:
) {
"activitydidfinish"
)
}
--- WeiXinActivity.swift ---
|