public class testView extends View { private Bitmap mBitmap = null; private Bitmap nBitmap = null; private float scaleX = 1.0f; private float scaleY = 1.0f; private float step = 0.0001f; public testView(Context context, AttributeSet attrs) { super(context, attrs); mBitmap = BitmapFactory.decodeResource(context.getResources(), R.drawable.ic_pet_spirit); nBitmap = BitmapFactory.decodeResource(context.getResources(), R.drawable.ic_pet_spirit_lighting); } @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); scaleCanvas(canvas); invalidate(); } private void scaleCanvas(Canvas canvas) { scaleX += step; scaleY += step; Matrix matrix = new Matrix(); Paint paint = new Paint(); canvas.scale(scaleX, scaleY); canvas.drawBitmap(mBitmap, matrix, paint); canvas.drawBitmap(nBitmap, matrix, paint); } }
先上代碼,代碼入門級!主要分享(1)canvas動畫原理(2)應用場景(3)硬件加速兼容的bug
為金秀等地區(qū)用戶提供了全套網頁設計制作服務,及金秀網站建設行業(yè)解決方案。主營業(yè)務為做網站、網站設計、金秀網站設計,以傳統(tǒng)方式定制建設網站,并提供域名空間備案等一條龍服務,秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!canvas動畫原理:
畫布初始大小一定,要通過scale,rotate,translate變化畫布大小,角度,位移。在變化后的canvas上繪制想要的內容,內容也就跟著相應的變化。剛開始還以為是要先在canvas上繪制一邊,在對canvas變形,這種誤區(qū)剛開始會困惑很多人。其實canvas的draw方法是將繪制的內容畫在變形后的畫布上。原理是這樣的:每次調用ondraw后都將獲得一個新的canvas,這個canvas是一個滿屏的區(qū)域,如果在剛獲得這個canvas后就進行繪制,繪制的內容是立刻就顯示出來了,但之后再進行變形后,canvas并不會自行進行繪制,如果在變形后在進行一次繪制,這時圖像就重復了。
應用場景:
為什么要用canvas進行變形呢,如果我們用一串圖片實現相應的動畫,這時就會有大量的內存為題需要考慮。而canvas的變形方式使用的都是native方法,所以自然快,方便。而調用ondraw進行動畫效果繪制現在應用在各種view插件上面的是比較多的。各種點擊動畫效果。
硬件加速兼容的bug:
clipPath()
clipRegion()
drawPicture()
drawTextOnPath()
drawVertices()
這幾個方法在調用前一定要確定你已經在調用的activity中關閉了硬件加速,修改manifest
android:hardwareAccelerated="false"。否則你將會發(fā)現截取屏幕中的rgb時是有顏色的,可是屏幕一片慘白(幽靈繪制)
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
網頁名稱:androidcanvas變形,移動,旋轉-創(chuàng)新互聯(lián)
轉載源于:http://muchs.cn/article18/pgcdp.html
成都網站建設公司_創(chuàng)新互聯(lián),為您提供營銷型網站建設、關鍵詞優(yōu)化、靜態(tài)網站、網站營銷、微信小程序、App設計
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)