學習HM微博項目第8天

步驟:發微博01-導航欄內容 -> 發微博02-自定義TextView -> 發微博03-完善TextView和發送微博按鈕 -> 發微博04-顯示工具條 -> 發微博05-封裝工具條和相冊 -> 發微博06-發送微博

發微博01-導航欄內容

APP的演示操作:

APP的演示操作

從APP的演示操作中可知,當點擊tabBar的“+”按鈕時APP會以modal的方式跳轉到發微博的控制器。實現代碼如下:

跳轉到發微博的控制器

在HMComposeViewController類的viewDidLoad方法中,設置導航欄內容,并添加輸入控件(用于輸入微博正文),如下:

HMComposeViewController類的viewDidLoad方法

HMComposeViewController類的初始化方法如下:

setupNav方法
setupTextView方法

發微博02-自定義TextView

APP的演示操作:

APP的演示操作

前文中,已經初步添加了輸入控件UITextView,但是輸入控件UITextView并不能完全滿足我們的要求,即無法實現占位文字。

所以,新建了一個繼承自UITextView的HMTextView類,將占位文字的實現以及輸入控件的具體邏輯都封裝到HMTextView類中,只將占位文字和占位文字顏色兩個屬性提供給外界(HMComposeViewController類)使用。如下:

完善后的setupTextView方法

在HMTextView類中,占位文字的實現有多種方式:第一種是添加UILabel,第二種是重寫drawRect:方法。在這里,我們采用的是第二種方式。重寫drawRect:方法,如下:

重寫drawRect:方法

觀察APP的演示操作,一開始進入發微博界面時,輸入控件上顯示的是“分享新鮮事”,當我們輸入文字后,“分享新鮮事”就會“消失”。這里的實現原理是通知。具體代碼如下:

通知

注意:這里不適合使用代理,用通知即可。發出通知后,會觸發textDidChange事件,然后重新調用drawRect方法進行重繪。

發微博03-完善TextView和發送微博按鈕

APP的演示操作:

APP的演示操作

在前文的基礎上繼續完善輸入控件,并且當有輸入文字后,導航欄的右邊發送按鈕可以響應(發送微博)。

參考前面,HMComposerViewController監聽輸入文字同樣是采用通知的方式。如下:

通知

其中,textDidChange方法的具體代碼如下:

textDidChange方法

在HMComposerViewController中,監聽方法send是用于發送微博,具體代碼如下:

send方法

說明:
1.完善前文中設置導航欄內容的代碼,要考慮是否有微博名,如下:

setupNav方法

2.HMTextView類聲明了兩個屬性placedholder和placedholderColor,由于這兩個屬性不是系統屬性,所以在優先級上會較低,我們有時候需要重寫它們的setter方法,如下:

HMTextView.m

3.每一次使用通知,都要注意調用dealloc方法,移除觀察者。如下:

移除觀察者

發微博04-顯示工具條

APP的演示操作:

APP的演示操作

仔細觀察APP的演示操作,工具條一開始是顯示在屏幕底部,當鍵盤彈出時工具條才移動到鍵盤的頂部。

在HMComposeViewController的viewDidLoad方法添加工具條,如下:

HMComposeViewController的viewDidLoad方法

其中,setupToolBar方法如下:

setupToolBar方法
問題:對于工具條的類HMComposerToolbar暫時不要考慮,先弄明白為什么當鍵盤一出現工具條就會移動鍵盤的頂部?實現原理是什么?

思路:
1.鍵盤會在進入發微博頁面后就彈出是因為調用了viewDidAppear:方法,如下:

viewDidAppear:方法

2.彈出鍵盤后移動工具條,這是因為當鍵盤的frame發生改變時就會發出通知UIKeyboardWillChangeFrameNotification,觸發keyboardWillChangeFrame:事件, 執行動畫移動工具條,如下:

setupTextView方法

其中,keyboardWillChangeFrame:方法,如下:

keyboardWillChangeFrame:方法

在HMComposerToolbar類(繼承自UIView)中,設置工具條上的按鈕。具體代碼如下:

@implementation HMComposeToolbar

- (id)initWithFrame:(CGRect)frame
{
    self = [super initWithFrame:frame];
    if (self) {
         self.backgroundColor = [UIColor colorWithPatternImage:[UIImage imageNamed:@"compose_toolbar_background"]];
        
        //初始化按鈕
        [self setupBtn:@"compose_camerabutton_background" highImage:@"compose_camerabutton_background_highlighted"];
        [self setupBtn:@"compose_toolbar_picture" highImage:@"compose_toolbar_picture_highlighted"];
        [self setupBtn:@"compose_mentionbutton_background" highImage:@"compose_mentionbutton_background_highlighted"];
        [self setupBtn:@"compose_trendbutton_background" highImage:@"compose_trendbutton_background_highlighted"];
        [self setupBtn:@"compose_emoticonbutton_background" highImage:@"compose_emoticonbutton_background_highlighted"];

    }
    return self;
}

/**
 *  創建一個按鈕
 */
- (void)setupBtn:(NSString *)image highImage:(NSString *)highImage
{
    UIButton *btn = [[UIButton alloc] init];
    [btn setImage:[UIImage imageNamed:image] forState:UIControlStateNormal];
    [btn setImage:[UIImage imageNamed:highImage] forState:UIControlStateHighlighted];
    
    [self addSubview:btn];
    
}

/**
 *  設置按鈕的尺寸
 */
- (void)layoutSubviews
{
    [super layoutSubviews];
    
    //設置按鈕的frame
    NSUInteger btnCount = self.subviews.count;
    CGFloat btnW = self.size.width / 5;
    CGFloat btnH = self.size.height;
    for (int i = 0; i< btnCount; i++) {
        UIButton *btn = self.subviews[i];
        btn.x = i * btnW;
        btn.y = 0;
        btn.width = btnW;
        btn.height = btnH;
    }
}
@end

發微博05-封裝工具條和相冊

APP的演示操作:

APP的演示操作

仔細觀察APP的演示操作,在輸入文字下面添加了相冊,用于顯示發微博的圖片。而工具條上的按鈕也可以響應某些事件。其實現過程相當復雜。

在HMComposeViewController的viewDidLoad方法添加相冊,如下:

HMComposeViewController的viewDidLoad方法

其中,setupPhotosView方法如下:

setupPhotosView方法

在HMComposePhotosView(繼承自UIView)中,添加圖片到發微博的相冊中,設置圖片的frame。關鍵代碼如下:

HMComposePhotosView.m

其中,要將方法addPhoto提供外界,用于從外界添加圖片。

在HMComposeToolbar類,完善之前的代碼,使得工具條上的按鈕可以響應。不同于之前所用到的通知,這里要通過代理來實現按鈕的點擊事件。
過程:
1.聲明代理協議和代理屬性,具體代碼如下:

聲明代理協議和代理屬性

2.通知代理對象,具體代碼如下:

通知代理對象

說明:由于使用到btn.tag,所以要對之前的代碼進行完善,如下:


setupBtn:highImage:type:方法

在HMComposeViewController中,遵守HMComposeToolbarDeleagate代理協議,實現代理方法,如下:

HMComposeToolbarDeleagate代理方法

其中,openCamera和openAlbum方法分別對應工具條上的“拍照”和“相冊”按鈕。具體代碼如下:

openCamera和openAlbum方法

openImagePickerController:設置代理,遵守
UINavigationControllerDelegate和UIImagePickerControllerDelegate代理協議,實現代理方法imagePickerController:didFinishPickingMediaWithInfo:方法,如下:

imagePickerController:didFinishPickingMediaWithInfo:方法

在imagePickerController:didFinishPickingMediaWithInfo:方法中,取出系統相冊里的圖片后,調用HMComposePhotosView類的addPhoto方法,將圖片添加到發微博的相冊photosView中。

發微博06-發送微博

APP的演示操作:

APP的演示操作

仔細觀察APP的演示操作,此時發微博除了發送文字,還可以發送圖片。截圖如下:

所發送的微博截圖

實際上,在前文的send方法中的api接口是沒辦法發送圖片的,需要另外一個接口。這就需要我們考慮兩種情況(有圖片和沒圖片)。
完善send方法,具體代碼如下:

send方法

其中,sendWithImage方法如下:

sendWithImage方法

sendWithoutImage方法如下:

sendWithoutImage方法

說明:
1.發送帶有圖片的微博,需要將圖片上傳到新浪的服務器。
這就涉及HMComposePhotosView類,需要HMComposePhotosView類提供photos屬性給外界用來獲取圖片資源。
由于外界沒必要對圖片資源進行修改,只需要獲取即可。所以對photos屬性進行特殊聲明(readonly)。如下:

HMComposePhotosView類的photos屬性

并且要完善下addPhoto方法的代碼,如下:

完善addPhoto方法

總結:主要掌握好工具條的設置和如何移動,并且進一步加深對readonly屬性的認識。

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

推薦閱讀更多精彩內容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,605評論 25 708
  • 發現 關注 消息 iOS 第三方庫、插件、知名博客總結 作者大灰狼的小綿羊哥哥關注 2017.06.26 09:4...
    肇東周閱讀 12,151評論 4 61
  • 子曰:“工欲善其事,必先利其器。” 據上周六平整土地的覺悟,爪鉤才是敲土利器。 今天一早到湯山農貿市場后,直奔農具...
    心花朵朵閱讀 368評論 1 1
  • 有一種一塊大石頭終于落地的感覺。 雖然我知道其實我們這邊是個小石頭。 不過還是好開心啊,可以放松...
    _aqu閱讀 336評論 2 0
  • 寫郵件不是搞文學創作,其實只要遵循一個原則,你就不會寫出讓對方吐槽的郵件,那就是:不寫自己知道的,而寫對方需要知道...
    8a0feaba5d61閱讀 770評論 0 0