溫馨提示×

溫馨提示×

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

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

ios中如何實(shí)現(xiàn)貝塞爾曲線切割圓角

發(fā)布時間:2021-07-09 09:32:32 來源:億速云 閱讀:137 作者:小新 欄目:移動開發(fā)

這篇文章主要為大家展示了“ios中如何實(shí)現(xiàn)貝塞爾曲線切割圓角”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“ios中如何實(shí)現(xiàn)貝塞爾曲線切割圓角”這篇文章吧。

ios 系統(tǒng)框架已經(jīng)給我們提供了相應(yīng)的切割圓角的方法, 但是如果在一個見面有很多控件切割的話會出現(xiàn)卡頓和個別不切得現(xiàn)在

/* 創(chuàng)建一個Button */
   UIButton * button = [UIButton buttonWithType:(UIButtonTypeSystem)];
   [button setFrame:CGRectMake(100, 100, 100, 100)];
   [self addSubview:button]; 

/* 正廠的圓角需求處理方法 */

  button.layer.cornerRadius = 10.0f; //弧度
  button.layer.masksToBounds = YES;

/* 貝塞爾曲線切割 */
  /**
   *
   * @param UIRectCorner 
   * 左上 UIRectCornerTopLeft   = 1 << 0, 
    左下 UIRectCornerBottomLeft = 1 << 2, 
    右下 UIRectCornerBottomRight = 1 << 3, 
    所有角 UIRectCornerAllCorners = ~0UL
   *
   */
UIBezierPath *maskPath = [UIBezierPath bezierPathWithRoundedRect:button.bounds byRoundingCorners:UIRectCornerTopLeft | UIRectCornerBottomLeft cornerRadii:button.bounds.size];
  CAShapeLayer *maskLayer = [[CAShapeLayer alloc]init];
  //設(shè)置大小
  maskLayer.frame = button.bounds;
  //設(shè)置圖形樣子
  maskLayer.path = maskPath.CGPath;
  button.layer.mask = maskLayer;

注意: 如果這里選擇兩個角 的話如果是選兩個對角線 則會切 所有角

比如:UIRectCornerTopLeft | UIRectCornerBottomRight 他就會切割所有角

當(dāng)然你也可以直接創(chuàng)建個圓角的button

以上是“ios中如何實(shí)現(xiàn)貝塞爾曲線切割圓角”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

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

ios
AI