swift--TabBar上自定義按鈕,以及出現(xiàn)的坑

效果圖

A4D71D47-1C38-4409-A785-E44C3BED860B.png

代碼實現(xiàn)

代碼的核心就是計算按鈕的位置

     let cout = CGFloat(childViewControllers.count)  
        let width = tabBar.bounds.width/cout
        composeButton.frame=tabBar.bounds.insetBy(dx: 2*width, dy:-20)
        composeButton.layer.cornerRadius=width/5
        composeButton.clipsToBounds=true
        tabBar.addSubview(composeButton)

這樣會導致點擊按鈕和消息之間出現(xiàn)空白,原因就是容錯點的出現(xiàn)。

容錯點:兩個按鈕之間會有間隙,用手點擊不會出錯,但是鼠標比較精確。

解決方法:把寬度減1,// 將向內縮進的寬度減少,能夠讓按鈕的寬度變大

     let cout = CGFloat(childViewControllers.count)
        let width = tabBar.bounds.width/cout-1
        composeButton.frame=tabBar.bounds.insetBy(dx: 2*width, dy:-20)
        composeButton.layer.cornerRadius=width/5
        composeButton.clipsToBounds=true
        tabBar.addSubview(composeButton)

這里多說一句,tabBar.bounds.insetBy(dx: 2*width, dy:-20)這里類似與OC的cgrectInsert,正數(shù)向內縮進,負數(shù)向外擴展。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容