Quartz 2D提供了CGContextAddCurveToPoint()和CGContextAddQuadCurveToPoint()兩個函數(shù)向CGContextRef的當前路徑上添加曲線前者用于添加貝塞爾曲線后者用于添加二次曲線。
10年積累的做網(wǎng)站、網(wǎng)站設計經(jīng)驗,可以快速應對客戶對網(wǎng)站的新想法和需求。提供各種問題對應的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡服務。我雖然不認識你,你也不認識我。但先網(wǎng)站策劃后付款的網(wǎng)站建設流程,更有橋東免費網(wǎng)站建設讓你可以放心的選擇與我們合作。繪制貝塞爾曲線的示意圖如圖12.10所示。從圖12.10可以看出確定一條貝塞爾曲線需要4個點開始點、第一個控制點、第二個控制點和結(jié)束點。
圖12.10繪制貝塞爾曲線示意圖
CGContextAddCurveToPoint(CGContextRef c, float cpx1, float cpy1, float cpx2, float cpy2, float x, float y)方法則負責繪制從路徑的當前點作為開始點到結(jié)束點x、y的貝塞爾曲線其中cpx1、cpy1定義第一個控制點的坐標cpx2、cpy2定義第二個控制點的坐標。
繪制二次曲線的示意圖如圖12.11所示。
從圖12.11可以看出確定一條二次曲線需要三個點開始點、控制點和結(jié)束點。
CGContextAddQuadCurveToPoint(CGContextRef c, float cpx, float cpy, float x, float y)方法則負責繪制從路徑的當前點作為開始點到結(jié)束點x、y的二次曲線其中cpx、cpy定義控制點的坐標。
圖12.11繪制二次曲線示意圖
下面的程序使用了CGContextAddQuadCurveToPoint()函數(shù)方法繪制多條相連的曲線這樣就可添加花朵形狀的路徑。將下面的函數(shù)添加到FKContext.h函數(shù)庫中方便以后復用。添加花朵路徑的函數(shù)代碼如下。
程序清單codes/12/12.2/CurveTest/CurveTest/FKContext.h
上面的粗體字代碼每次都會計算二次曲線結(jié)束點、控制點的坐標然后調(diào)用CGContext AddQuadCurveToPoint()函數(shù)即可添加二次曲線路徑。程序采用循環(huán)控制繪制多條前后相連的曲線這樣即可形成花瓣。
實例使用曲線繪制多瓣花朵
下面創(chuàng)建一個應用程序來測試該添加花瓣曲線的函數(shù)。首先創(chuàng)建一個Single View Application該Application包含一個應用程序委托代理類、一個視圖控制器和配套的Storyboard界面設計文件。將該界面設計文件中大的View改為使用自定義的FKCurveView類。該程序的控制器類幾乎無須修改只要重寫FKCurveView的drawRect:方法在該方法中調(diào)用FKContext.h中的方法來添加花瓣路徑然后采用不同的顏色填充該路徑即可。
下面是該FKCurveView類的實現(xiàn)代碼。
程序清單codes/12/12.2/CurveTest/CurveTest/ FKCurveView.m
程序中的三行粗體字代碼分別添加5瓣花朵路徑、6瓣花朵路徑、7瓣花朵路徑然后使用不同的顏色來填充這些路徑。注意到上面的程序并未在每次添加花朵路徑后立即關(guān)閉這也是允許的而且每次填充路徑時并不會再次填充前一次已經(jīng)填充過的路徑。這是因為只用程序繪制了CGContextRef當前所包含的路徑系統(tǒng)會自動清除已經(jīng)繪制的路徑。
注意
每次繪制完成后CGContextRef會自動清除已經(jīng)繪制完成的路徑。
編譯、運行該程序可以看到如圖12.12所示的花朵。
圖12.12使用二次曲線繪制花朵示例
——————本文節(jié)選自《瘋狂ios講義上》
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
當前題目:瘋狂ios講義瘋狂連載之繪制曲線-創(chuàng)新互聯(lián)
轉(zhuǎn)載來于:http://www.rwnh.cn/article42/eschc.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供軟件開發(fā)、App開發(fā)、網(wǎng)站排名、用戶體驗、小程序開發(fā)、標簽優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容