自定義社交化分享面板

1、shardSDK的分享面板我們不要說他丑了,雖然它確實不好看。那么自己動手豐衣足食,那就果斷自定義一個吧:(支持QQ\微信\QQZone\朋友圈\收藏,彈出和收回動畫、點擊背景隱藏)

//
//  ShareCustom.m
//  mplus
//
//  Created by Axiba on 16/3/27.
//  Copyright ? 2016年 Zero. All rights reserved.
//

#import "ShareCustom.h"
#import "UIView+Extension.h"
#import "NSString+Extension.h"
#import <QuartzCore/QuartzCore.h>
#import <ShareSDK/ShareSDK.h>
#import <ShareSDKUI/ShareSDK+SSUI.h>

@implementation ShareCustom

static NSMutableDictionary *_publishContent;//類方法中的全局變量這樣用(類型前面加static)

+(void)shareWithContent:(NSMutableDictionary *)publishContent
{
    _publishContent = publishContent;
    UIWindow *window = [UIApplication sharedApplication].keyWindow;
    
    //背景顏色
    UIView *blackView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, fDeviceWidth, fDeviceHeight)];
    blackView.backgroundColor = XBAColor(0, 0, 0, 0.6);
    blackView.tag = 440;
    UITapGestureRecognizer *blackGestureRecognizer = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(cancelPanGesture)];
    [blackView addGestureRecognizer:blackGestureRecognizer];
    blackView.userInteractionEnabled = YES;
    [window addSubview:blackView];
    
    //分享面板
    UIView *shareView = [[UIView alloc] initWithFrame:CGRectMake(0, fDeviceHeight-300*KWidth_Scale, fDeviceWidth, 300*KWidth_Scale)];
    shareView.backgroundColor = XBColor(241, 244, 245);
    shareView.tag = 441;
    [window addSubview:shareView];
    
    //頂部的文字
    UILabel *titleLabel = [[UILabel alloc] init];
    titleLabel.text = @"分享給好友";
    CGSize createSize = [titleLabel.text sizeWithTextFont:[UIFont systemFontOfSize:16*KWidth_Scale]];
    titleLabel.frame = (CGRect){{0, 16*KWidth_Scale}, createSize};
    titleLabel.centerX = shareView.centerX;
    titleLabel.textAlignment = NSTextAlignmentCenter;
    titleLabel.font = [UIFont systemFontOfSize:16*KWidth_Scale];
    titleLabel.textColor = XBColor(51, 51, 51);
    titleLabel.backgroundColor = [UIColor clearColor];
    [shareView addSubview:titleLabel];
    
    //文字左\右邊的線條
    UIView *nothingImg = [[UIView alloc] init];
    nothingImg.backgroundColor = XBColor(220,220,220);
    nothingImg.height = 0.5;
    nothingImg.width = (shareView.width - (30 + 40)*KWidth_Scale - titleLabel.width)/2;
    nothingImg.y = titleLabel.centerY;
    nothingImg.x = 20*KWidth_Scale;
    [shareView addSubview:nothingImg];
    
    UIView *nothingRImg = [[UIView alloc] init];
    nothingRImg.backgroundColor = XBColor(220,220,220);
    nothingRImg.height = 0.5;
    nothingRImg.width = (shareView.width - (30 + 40)*KWidth_Scale - titleLabel.width)/2;
    nothingRImg.y = titleLabel.centerY;
    nothingRImg.x = shareView.width - 20*KWidth_Scale - nothingRImg.width;
    [shareView addSubview:nothingRImg];
    
    NSArray *btnImages = @[@"分享-QQ空間", @"分享_qq_icon", @"分享_微信_icon", @"分享_朋友圈_icon",  @"分享-復制鏈接"];
    NSArray *btnTitles = @[@"QQ空間", @"QQ",  @"微信", @"朋友圈", @"復制"];
    CGFloat textlbH = 0;
    for (NSInteger i=0; i < btnImages.count; i++) {
        
        UIImage *img = [UIImage imageNamed:btnImages[i]];
        UIButton *button = [[UIButton alloc] init];
        [button setImage:img forState:UIControlStateNormal];
        
        CGFloat top = 0.0f;
        if (i<4) {
            top = 20*KWidth_Scale;
            
        }else{
            top = (20 + img.size.width + 28)*KWidth_Scale + textlbH;
        }
        CGFloat margin = (mainSize.width - img.size.width*KWidth_Scale*4)/5;
        
        button.x = (i%4 + 1)*margin + (i%4)*img.size.width*KWidth_Scale;
        button.y = CGRectGetMaxY(titleLabel.frame) + top;
        button.width = img.size.width*KWidth_Scale;
        button.height = img.size.height*KWidth_Scale;
        button.tag = 331+i;
        [button addTarget:self action:@selector(shareBtnClick:) forControlEvents:UIControlEventTouchUpInside];

        [shareView addSubview:button];
        
        UILabel *createlb = [[UILabel alloc]init];
        CGSize createSize = [btnTitles[i] sizeWithTextFont:[UIFont systemFontOfSize:12]];
        createlb.frame = (CGRect){{0, CGRectGetMaxY(button.frame) + 8*KWidth_Scale}, createSize};
        createlb.centerX = button.centerX;
        createlb.textAlignment = NSTextAlignmentCenter;
        createlb.text = btnTitles[i];
        createlb.textColor = XBAColor(51, 51, 51, 1);
        createlb.font = [UIFont systemFontOfSize:12];
        textlbH = createlb.height;
        [shareView addSubview:createlb];

    }
    
    UIButton *cancleBtn = [[UIButton alloc] initWithFrame:CGRectMake(0, shareView.height-44*KWidth_Scale, mainSize.width, 44*KWidth_Scale)];
    [cancleBtn setTitle:@"取消" forState:UIControlStateNormal];
    [cancleBtn setBackgroundColor:XBColor(255, 255, 255)];
    [cancleBtn setTitleColor:XBAColor(51, 51, 51, 1) forState:UIControlStateNormal];
    cancleBtn.titleLabel.font = [UIFont systemFontOfSize:17*KWidth_Scale];
    cancleBtn.tag = 339;
    [cancleBtn addTarget:self action:@selector(cancelWithRemoveShareView) forControlEvents:UIControlEventTouchUpInside];
    [shareView addSubview:cancleBtn];
    
    //為了彈窗不那么生硬,這里加了個簡單的動畫
    shareView.frame = CGRectMake(0, mainSize.height, shareView.width, shareView.height);
    [UIView animateWithDuration:0.35f animations:^{
        shareView.frame = CGRectMake(0, mainSize.height-shareView.height,  shareView.width, shareView.height);
    }];
}

+(void)shareBtnClick:(UIButton *)btn
{
    //移除分享面板
    [self cancelWithRemoveShareView];
    
    int shareType = 0;
    NSMutableDictionary *publishContent = _publishContent;
    switch (btn.tag) {
        case 331:
        {
            shareType = SSDKPlatformSubTypeQZone;
        }
            break;
            
        case 332:
        {
            shareType = SSDKPlatformSubTypeQQFriend;
        }
            break;
            
        case 333:
        {
            shareType = SSDKPlatformSubTypeWechatSession;
        }
            break;
        case 334:
        {
            shareType = SSDKPlatformSubTypeWechatTimeline;
        }
            break;
        case 335:
        {
            shareType = SSDKPlatformTypeCopy;
        }
            break;
            
        default:
            break;
    }
    
    /*
     調用shareSDK的無UI分享類型
     */
    [ShareSDK share:shareType parameters:publishContent onStateChanged:^(SSDKResponseState state, NSDictionary *userData, SSDKContentEntity *contentEntity, NSError *error) {
        
        switch (state) {
            case SSDKResponseStateSuccess:
            {
                NSString *resulTitle = [NSString stringWithFormat:(shareType == SSDKPlatformTypeCopy) ? @"復制成功" : @"分享成功"];
                UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:resulTitle
                                                                    message:nil
                                                                   delegate:nil
                                                          cancelButtonTitle:@"確定"
                                                          otherButtonTitles:nil];
                [alertView show];
                break;
            }
            case SSDKResponseStateFail:
            {
                UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"分享失敗"
                                                                message:[NSString stringWithFormat:@"%@",error]
                                                               delegate:nil
                                                      cancelButtonTitle:@"OK"
                                                      otherButtonTitles:nil, nil];
                [alert show];
                break;
            }
            default:
                break;
        }
    }];
}

+(void)cancelWithRemoveShareView{
    UIWindow *window = [UIApplication sharedApplication].keyWindow;
    UIView *blackView = [window viewWithTag:440];
    UIView *shareView = [window viewWithTag:441];
    
    //為了移除彈窗不那么生硬,這里加了個簡單的動畫
    shareView.frame = CGRectMake(0, mainSize.height-shareView.height, shareView.width, shareView.height);
    [UIView animateWithDuration:0.35f animations:^{
        shareView.frame = CGRectMake(0, mainSize.height,  shareView.width, shareView.height);
    } completion:^(BOOL finished) {
        
        [shareView removeFromSuperview];
        [blackView removeFromSuperview];
    }];
}
+(void)cancelPanGesture{
    [self cancelWithRemoveShareView];
}

@end

2、那么調用這個自定義類的方式就是:

-(void)shareURL:(UIButton *)button{
    
    NSArray* imageArray = @[[UIImage imageNamed:@"logo-圖標"]];
    NSMutableDictionary *shareParams = [NSMutableDictionary dictionary];
    [shareParams SSDKSetupShareParamsByText:@"山重水復疑無路,柳暗花明還不行"
                                     images:imageArray
                                        url:[NSURL URLWithString:@"http://www.lxweimin.com/p/f3d62ad7a2bb"]
                                      title:@"山重水復疑無路,柳暗花明還不行"
                                       type:SSDKContentTypeAuto];
    
    //調用自定義分享
    [ShareCustom shareWithContent:shareParams];
}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,197評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,415評論 3 415
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,104評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,884評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,647評論 6 408
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,130評論 1 323
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,208評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,366評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,887評論 1 334
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,737評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,939評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,478評論 5 358
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,174評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,586評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,827評論 1 283
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,608評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,914評論 2 372

推薦閱讀更多精彩內容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,630評論 25 708
  • 發現 關注 消息 iOS 第三方庫、插件、知名博客總結 作者大灰狼的小綿羊哥哥關注 2017.06.26 09:4...
    肇東周閱讀 12,151評論 4 61
  • 兒子四歲多了,語言突飛猛進,有時讓我們驚詫不已,有時又讓我們引俊不禁。 1、大清早,一家三口去診所按摩。停車場上車...
    微霞滿天閱讀 522評論 2 3
  • 本文摘自《米其林大師從未說出的34條成功哲學》,作者本田直之通過采訪進軍國際,并獲得一定成就的15位名廚及侍酒師,...
    努力攢錢的二花閱讀 353評論 0 0