iOS 仿微信發(fā)送語音消息按鈕 - 手勢按鈕(一)

最近在做基于XMPP的IM,開發(fā)到發(fā)送語音消息的功能.在某度上搜了很久也沒有找到適合的方法.索性自己琢磨了一個,提供給大家參考.(其中找到的很多文章都是一個復(fù)制另一個的,很煩!沒格式?jīng)]頭沒尾的.給不了人任何思路的一堆文字)

發(fā)送語音功能模塊主要有三個模塊

Part 1 :手勢按鈕

仿照經(jīng)常使用的微信"發(fā)送消息"按鈕.當(dāng)時第一想法就是想到- (BOOL)containsPoint:(CGPoint)p;方法.

直接上代碼

.h

#import <UIKit/UIKit.h>

@protocol DPChatToolBarAudioDelegate <NSObject>

/*
 * 錄音完成
 *
 * @param audioData amr文件data
 * @prram body      附帶信息,比如錄音時長等信息
 */
- (void)DPAudioRecordingFinishWithData:(NSData *)audioData withBodyString:(NSString *)body;

@optional

/*
 * 開始錄音
 *
 * @param isRecording 是否開始
 *
 */
- (void)DPAudioStartRecording:(BOOL)isRecording;

/*
 * 錄音失敗
 */
- (void)DPAudioRecordingFail:(NSString *)reason;

/*
 * 音頻值測量
 *
 * @param power 音頻值
 */
- (void)DPAudioSpeakPower:(float)power;

@end

@interface ChatToolBarAudioButton : UIButton

@property (nonatomic, assign) id <DPChatToolBarAudioDelegate> delegate;

@end

.m

#import "ChatToolBarAudioButton.h"

@interface ChatToolBarAudioButton () <DPAudioRecorderDelegate>
{
    BOOL isShouldSendAudioMessage;         //用戶是否取消發(fā)送消息
    NSUInteger __block audioTimeLength; //錄音時長
}

@end

@implementation ChatToolBarAudioButton

- (instancetype)initWithFrame:(CGRect)frame
{
    if (self = [super initWithFrame:frame]) {
        
        self.layer.cornerRadius = 4;
        self.clipsToBounds = YES;
        [self.titleLabel setTextAlignment:NSTextAlignmentCenter];
        [self setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
        [self setTitle:@"按住 說話" forState:UIControlStateNormal];
        [self setTitle:@"松開 結(jié)束" forState:UIControlStateHighlighted];
        [self setBackgroundImage:[UIImage imageNamed:@"chatBar_recordBg"] forState:UIControlStateNormal];
        [self setBackgroundImage:[UIImage imageNamed:@"chatBar_recordSelectedBg"] forState:UIControlStateHighlighted];
        
        //增加長按手勢
        UILongPressGestureRecognizer *longPress = [[UILongPressGestureRecognizer alloc]initWithTarget:self action:@selector(longPress:)];
        longPress.minimumPressDuration = 0;
        [self addGestureRecognizer:longPress];
    }
    return self;
}

- (void)longPress:(UILongPressGestureRecognizer *)gestureRecognizer
{
    CGPoint point = [gestureRecognizer locationInView:self];
    
    if(gestureRecognizer.state == UIGestureRecognizerStateBegan) {
        [self setTitle:@"松開 結(jié)束" forState:UIControlStateNormal];
        [self setBackgroundImage:[UIImage imageNamed:@"chatBar_recordSelectedBg"] forState:UIControlStateNormal];
        [self audioStart];
    } else if(gestureRecognizer.state == UIGestureRecognizerStateEnded) {
        [self setTitle:@"按住 說話" forState:UIControlStateNormal];
        [self setBackgroundImage:[UIImage imageNamed:@"chatBar_recordBg"] forState:UIControlStateNormal];
        [self audioStop];
    } else if(gestureRecognizer.state == UIGestureRecognizerStateChanged) {
        if ([self.layer containsPoint:point]) {
            [self setTitle:@"松開 結(jié)束" forState:UIControlStateNormal];
            isCancelSendAudioMessage = NO;
        } else {
            [self setTitle:@"松開 取消" forState:UIControlStateNormal];
            isCancelSendAudioMessage = YES;
        }
    } else if (gestureRecognizer.state == UIGestureRecognizerStateFailed) {
        NSLog(@"失敗");
    } else if (gestureRecognizer.state == UIGestureRecognizerStateCancelled) {
        NSLog(@"取消");
    }
}

- (void)audioStart
{
    //開始錄音
    [[DPAudioRecorder sharedInstance] startRecording];
}

//結(jié)束錄音
- (void)audioStop
{
    [[DPAudioRecorder sharedInstance] stopRecording];
}

//錄音失敗
- (void)audioFailed
{
    //do something
}
@end

效果圖:

發(fā)送語音按鈕.gif

Demo 地址 :https://github.com/XL-Andrew/ChatToolBarAudioButton

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末箕速,一起剝皮案震驚了整個濱河市撕予,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌量淌,老刑警劉巖逸邦,帶你破解...
    沈念sama閱讀 206,214評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異枣耀,居然都是意外死亡霉晕,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評論 2 382
  • 文/潘曉璐 我一進(jìn)店門捞奕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來牺堰,“玉大人,你說我怎么就攤上這事颅围∥昂” “怎么了?”我有些...
    開封第一講書人閱讀 152,543評論 0 341
  • 文/不壞的土叔 我叫張陵院促,是天一觀的道長筏养。 經(jīng)常有香客問我,道長常拓,這世上最難降的妖魔是什么渐溶? 我笑而不...
    開封第一講書人閱讀 55,221評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮弄抬,結(jié)果婚禮上茎辐,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好拖陆,可當(dāng)我...
    茶點故事閱讀 64,224評論 5 371
  • 文/花漫 我一把揭開白布弛槐。 她就那樣靜靜地躺著,像睡著了一般慕蔚。 火紅的嫁衣襯著肌膚如雪丐黄。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,007評論 1 284
  • 那天孔飒,我揣著相機(jī)與錄音灌闺,去河邊找鬼。 笑死坏瞄,一個胖子當(dāng)著我的面吹牛桂对,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播鸠匀,決...
    沈念sama閱讀 38,313評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼蕉斜,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了缀棍?” 一聲冷哼從身側(cè)響起宅此,我...
    開封第一講書人閱讀 36,956評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎爬范,沒想到半個月后父腕,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,441評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡青瀑,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,925評論 2 323
  • 正文 我和宋清朗相戀三年璧亮,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片斥难。...
    茶點故事閱讀 38,018評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡枝嘶,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出哑诊,到底是詐尸還是另有隱情群扶,我是刑警寧澤,帶...
    沈念sama閱讀 33,685評論 4 322
  • 正文 年R本政府宣布镀裤,位于F島的核電站穷当,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏淹禾。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,234評論 3 307
  • 文/蒙蒙 一茴扁、第九天 我趴在偏房一處隱蔽的房頂上張望铃岔。 院中可真熱鬧,春花似錦、人聲如沸毁习。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,240評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽纺且。三九已至盏道,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間载碌,已是汗流浹背猜嘱。 一陣腳步聲響...
    開封第一講書人閱讀 31,464評論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留嫁艇,地道東北人朗伶。 一個月前我還...
    沈念sama閱讀 45,467評論 2 352
  • 正文 我出身青樓,卻偏偏與公主長得像步咪,于是被迫代替她去往敵國和親论皆。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,762評論 2 345

推薦閱讀更多精彩內(nèi)容

  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫猾漫、插件点晴、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,022評論 4 62
  • 焦點網(wǎng)絡(luò)三期中級班 翟沖【原創(chuàng)】分享第314天 2017.11.07 語文的知識又多又雜,瑣瑣碎碎悯周,考試如同...
    春暖花開zc閱讀 129評論 0 0
  • 深夜看完夏至未至羨慕這樣的青春自己大學(xué)四年的生活匆匆而過什么都沒有實現(xiàn)他們的友情愛情充實的生活看看自己每天混日子喜...
    圈__圈閱讀 171評論 0 0
  • 文/宗宗 又是一年校園十佳歌手季粒督,每年的這個時候,我都會早早地來占座队橙,好讓耳朵盡情飽餐坠陈。 按慣例,這會是一個秀恩愛...
    Zack要多喝熱水閱讀 353評論 2 2
  • <壹> 三月里,陰雨連綿的江南里難得有了一個好晴天解总,喬府里正在做一件大事贮匕,那便是同往年一樣---摘青梅。 “夫人花枫,...
    愛上魚的土豆閱讀 687評論 8 6