溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

iOS如何實現(xiàn)簡易的抽屜效果

發(fā)布時間:2022-08-08 11:18:33 來源:億速云 閱讀:165 作者:iii 欄目:開發(fā)技術

這篇文章主要介紹“iOS如何實現(xiàn)簡易的抽屜效果”,在日常操作中,相信很多人在iOS如何實現(xiàn)簡易的抽屜效果問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”iOS如何實現(xiàn)簡易的抽屜效果”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

1.添加需要實現(xiàn)抽屜效果的三個視圖,這里需要注意主視圖需要放在最后添加

// 左邊視圖
 ...
// 右邊視圖
  ...
// 主視圖
    UIView *mainView=[[UIView alloc]initWithFrame:self.view.bounds];
    mainView.backgroundColor=[UIColor greenColor];
    _mainView=mainView;
    [self.view addSubview:mainView];

2.實現(xiàn)左滑顯示左邊視圖,右滑出現(xiàn)右邊視圖

添加平移手勢和點擊手勢,實現(xiàn)左右滑動的監(jiān)聽和點擊復位的效果

// 添加平移手勢
    UIPanGestureRecognizer *panGes=[[UIPanGestureRecognizer alloc]initWithTarget:self action:@selector(panGes:)];
    [self.mainView addGestureRecognizer:panGes];
    // 添加點擊返回手勢
    UITapGestureRecognizer *tapGes=[[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(tap)];
    [self.view addGestureRecognizer:tapGes];

在平移手勢調(diào)用的方法中,通過偏移量來確定mainView的frame,實現(xiàn)動畫效果

  • 首先通過translationInView:方法獲取偏移量,通過偏移量的正負確定拖動的方向

  • 當手指松開后需要根據(jù)mainView的x值確定其視圖是定位到原始位置還是其縮放的位置

  • 要其視圖由當前點位移到目標位置,可以通過當前點到目標點的位移,然后調(diào)用frameWithOffsetX:方法獲得mainView的frame

#define targetR 300
#define targetL -300
- (void)panGes:(UIPanGestureRecognizer *)panGes
{
    // 獲取偏移量
    CGPoint tranP=[panGes translationInView:self.mainView];
    // 獲得位移后的視圖
    self.mainView.frame=[self frameWithOffsetX:tranP.x];
    // 判斷拖動方向
    if (self.mainView.frame.origin.x<0) {//向左
        self.rightView.hidden=NO;
    }else if(self.mainView.frame.origin.x>0)
    {// 向右
        self.rightView.hidden=YES;
    }
    // 當手指松開時,做自動定位
    CGFloat target=0;
    if (panGes.state==UIGestureRecognizerStateEnded) {
        if (self.mainView.frame.origin.x>0.5*screenW) {
            target=targetR;
        }else if(CGRectGetMaxX(self.mainView.frame)<0.5*screenW)
        {
            target=targetL;
        }
        //offset為當前點到其目標點的位移
        CGFloat offset=target-self.mainView.frame.origin.x;
        [UIView animateWithDuration:0.5 animations:^{
            self.mainView.frame=[self frameWithOffsetX:offset];
        }];
    }

    // 復位
    [panGes setTranslation:CGPointZero inView:self.mainView];

}
#define maxY 120
// 根據(jù)mainView在X軸方向位移確定mainView的尺寸
- (CGRect)frameWithOffsetX:(CGFloat)offsetX
{
    CGRect frame=self.mainView.frame;

    frame.origin.x+=offsetX;

    frame.origin.y=fabs(frame.origin.x / screenW * maxY);

    frame.size.height=screenH - frame.origin.y * 2;

    return frame;
}

3.如何讓其他文件也能實現(xiàn)抽屜效果

  • 首先拖入文件,然后新建一個新的ViewController,讓其繼承自我們導入的文件@interface ViewController :AZDrawerController

  • 新建要實現(xiàn)抽屜效果的界面,添加其視圖至我們的mainView中,并且讓其控制器也成為界面控制器的子控件,讓控制器單獨的管理

// 當一個控制器的View添加到另一個控制器的View上的時候,那此時View所在的控制器也應該成為上一個控制器的子控制器.
    AZTableViewController *vc1=[[AZTableViewController alloc]init];
    vc1.view.frame=self.mainView.bounds;
    [self.mainView addSubview:vc1.view];
    [self addChildViewController:vc1];

iOS如何實現(xiàn)簡易的抽屜效果

到此,關于“iOS如何實現(xiàn)簡易的抽屜效果”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關知識,請繼續(xù)關注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

ios
AI