部分不常用方法收集

-(void)sizeToFit;

resize自己该贾,讓自己更貼近子視圖理澎,最大的節(jié)省空間,比如:我知道了label.text = @"aoegaieg",這里我可以調(diào)用[label sizeToFit]label就會自己調(diào)整尺寸峦嗤,而不用我們自己來計算寬度和高度了凡壤;如果是想size自己到superView(沒有嘗試曹体,大概是讓自己最大化填充superView),需要先將自己add到superView除抛,然后再調(diào)用這個方法喘漏;

這個方法不能重寫,如果需要調(diào)整默認的size方式比吭,可以重寫sizeThatFits:這個方法運行任何需要的計算,并返回給sizeToFit

UIPageViewController

一般是用來做電子書翻頁的效果的控制器;他實現(xiàn)的原理實際上是:一個fatherViewController管理著下面的subViewControllers鉴象;動畫效果有兩個,一個pageCurl(這就是翻頁的效果)隔盛,一個是scroll

如何操作:

- (void)click:(id)btn{

    //初始化一個pageVC
    UIPageViewController *pageVC = [[UIPageViewController alloc] 
initWithTransitionStyle:UIPageViewControllerTransitionStylePageCurl 
navigationOrientation:UIPageViewControllerNavigationOrientationHorizontal 
options:@{UIPageViewControllerOptionSpineLocationKey : 
@(UIPageViewControllerSpineLocationMin), 
UIPageViewControllerOptionInterPageSpacingKey : @(0)}];
    
    pageVC.dataSource = self;
    pageVC.delegate = self;
    
    self.array = @[[[AViewController alloc] init], [[BViewController alloc] init], [[AViewController alloc] init], [[BViewController alloc] init]];
    
   // 這里設(shè)置第一個顯示的vc,如果是'doubleSided'(雙面效果泥技,也就是正面為A店茶,背面為B) = 'YES' 并且spine location(暫時可以理解為書的背脊)不是'UIPageViewControllerSpineLocationMid',那么這里的array必須包含兩個元素族壳;
    [pageVC setViewControllers:@[self.array[0]] 
direction:UIPageViewControllerNavigationDirectionForward animated:YES completion:nil];
    
    [self.navigationController pushViewController:pageVC animated:YES];
}

//dataSoure協(xié)議中讓pageVC知道如何排序拢操;
- (nullable UIViewController *)pageViewController:(UIPageViewController *)pageViewController viewControllerBeforeViewController:(UIViewController *)viewController;
- (nullable UIViewController *)pageViewController:(UIPageViewController *)pageViewController viewControllerAfterViewController:(UIViewController *)viewController;
2516123-0963f996a37d64ce.png

CAEmitterLayer

粒子圖層,例如直播中不停冒泡的動畫就是這樣實現(xiàn)的

 if (!_emitterLayer) {
        CAEmitterLayer *emitterLayer = [CAEmitterLayer layer];
        // 發(fā)射器在xy平面的中心位置
        emitterLayer.emitterPosition = CGPointMake(self.moviePlayer.view.frame.size.width-50,self.moviePlayer.view.frame.size.height-50);
        // 發(fā)射器的尺寸大小
        emitterLayer.emitterSize = CGSizeMake(20, 20);
        // 渲染模式
        emitterLayer.renderMode = kCAEmitterLayerUnordered;
        // 開啟三維效果
        //    _emitterLayer.preservesDepth = YES;
        NSMutableArray *array = [NSMutableArray array];
        // 創(chuàng)建粒子
        for (int i = 0; i<10; i++) {
            // 發(fā)射單元
            CAEmitterCell *stepCell = [CAEmitterCell emitterCell];
            // 粒子的創(chuàng)建速率吕漂,默認為1/s
            stepCell.birthRate = 1;
            // 粒子存活時間
            stepCell.lifetime = arc4random_uniform(4) + 1;
            // 粒子的生存時間容差
            stepCell.lifetimeRange = 1.5;
            // 顏色
            // fire.color=[[UIColor colorWithRed:0.8 green:0.4 blue:0.2 alpha:0.1]CGColor];
            UIImage *image = [UIImage imageNamed:[NSString stringWithFormat:@"good%d_30x30", i]];
            // 粒子顯示的內(nèi)容
            stepCell.contents = (id)[image CGImage];
            // 粒子的名字
            //            [fire setName:@"step%d", i];
            // 粒子的運動速度
            stepCell.velocity = arc4random_uniform(100) + 100;
            // 粒子速度的容差
            stepCell.velocityRange = 80;
            // 粒子在xy平面的發(fā)射角度
            stepCell.emissionLongitude = M_PI+M_PI_2;;
            // 粒子發(fā)射角度的容差
            stepCell.emissionRange = M_PI_2/6;
            // 縮放比例
            stepCell.scale = 0.3;
            [array addObject:stepCell];
        }
        
        emitterLayer.emitterCells = array;
        [self.moviePlayer.view.layer insertSublayer:emitterLayer below:self.catEarView.layer];
        _emitterLayer = emitterLayer;
    }
    return _emitterLayer;
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子油湖,更是在濱河造成了極大的恐慌鹅经,老刑警劉巖幻妓,帶你破解...
    沈念sama閱讀 218,858評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡势腮,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評論 3 395
  • 文/潘曉璐 我一進店門漫仆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來嫉鲸,“玉大人,你說我怎么就攤上這事歹啼。” “怎么了座菠?”我有些...
    開封第一講書人閱讀 165,282評論 0 356
  • 文/不壞的土叔 我叫張陵狸眼,是天一觀的道長。 經(jīng)常有香客問我浴滴,道長拓萌,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,842評論 1 295
  • 正文 為了忘掉前任升略,我火速辦了婚禮微王,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘品嚣。我一直安慰自己炕倘,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,857評論 6 392
  • 文/花漫 我一把揭開白布翰撑。 她就那樣靜靜地躺著罩旋,像睡著了一般。 火紅的嫁衣襯著肌膚如雪眶诈。 梳的紋絲不亂的頭發(fā)上涨醋,一...
    開封第一講書人閱讀 51,679評論 1 305
  • 那天,我揣著相機與錄音逝撬,去河邊找鬼浴骂。 笑死,一個胖子當(dāng)著我的面吹牛宪潮,可吹牛的內(nèi)容都是我干的溯警。 我是一名探鬼主播趣苏,決...
    沈念sama閱讀 40,406評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼愧膀!你這毒婦竟也來了拦键?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,311評論 0 276
  • 序言:老撾萬榮一對情侶失蹤檩淋,失蹤者是張志新(化名)和其女友劉穎芬为,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蟀悦,經(jīng)...
    沈念sama閱讀 45,767評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡媚朦,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了日戈。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片询张。...
    茶點故事閱讀 40,090評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖浙炼,靈堂內(nèi)的尸體忽然破棺而出份氧,到底是詐尸還是另有隱情,我是刑警寧澤弯屈,帶...
    沈念sama閱讀 35,785評論 5 346
  • 正文 年R本政府宣布蜗帜,位于F島的核電站,受9級特大地震影響资厉,放射性物質(zhì)發(fā)生泄漏厅缺。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,420評論 3 331
  • 文/蒙蒙 一宴偿、第九天 我趴在偏房一處隱蔽的房頂上張望湘捎。 院中可真熱鬧,春花似錦窄刘、人聲如沸窥妇。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽秩伞。三九已至,卻和暖如春欺矫,著一層夾襖步出監(jiān)牢的瞬間纱新,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評論 1 271
  • 我被黑心中介騙來泰國打工穆趴, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留脸爱,地道東北人。 一個月前我還...
    沈念sama閱讀 48,298評論 3 372
  • 正文 我出身青樓未妹,卻偏偏與公主長得像簿废,于是被迫代替她去往敵國和親空入。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,033評論 2 355

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