Canvas深入學習(二)----canvas坐標系

我記得我在剛開始接觸自定義控件的時候,當我拿到各種坐標點的時候入偷,我就知道它存在一個坐標系,但具體怎么個坐標系法械哟,卻不是太清楚盯串,今天就開始整理一下。
首先戒良,坐標系是依附于canvas上的,canvas實際上就是一個用來保存像素的Bitmap,我們自定義控件其實就是根據(jù)坐標在canvas上畫東西的一個過程冠摄。

canvas里的兩種坐標系

一糯崎、Canvas自己的坐標系

首先看一下圖

Canvas自己的坐標系

我們假設藍色的部分就是canvas畫板,那么canvas自己的坐標系原點就在左上角河泳,同時原點往右就是x軸的正半軸沃呢,往下就是y軸的正半軸

!!!需要注意的是,該坐標系有且只有一個拆挥,唯一不變

二薄霜、Canvas繪圖坐標系

繪圖坐標系不是唯一不變的,它與canvas的Matrix有關系纸兔,當Matrix發(fā)生改變的時候惰瓜,繪圖坐標系也對應著進行改變,同時這個過程是不可逆的汉矿。
Matrix又是通過我們設置translate(平移)崎坊、rotate(旋轉)、scale(縮放)洲拇、skew(斜拉)來進行改變

下面從坐標轉換來理解canvas繪圖坐標系
繪圖坐標系

來看代碼

        //首先初始化畫筆
        paint = new Paint();
        paint.setColor(Color.RED);//設置畫筆紅色
        paint.setStyle(Paint.Style.FILL);//填充內部
        paint.setAntiAlias(true);//消除鋸齒
        paint.setStrokeWidth(30);//寬度
        //為了方便觀察奈揍,先把canvas背景設置為灰色,再移動到點(200赋续,200)處
        canvas.drawColor(Color.GRAY);
        canvas.translate(200,200);
    
        先畫一個紅色的矩形
        RectF rectF = new RectF(0,0,600,700);
        canvas.drawRect(rectF,paint);

        //然后繪圖坐標系平移到點(100男翰,100),畫綠色的框框
        canvas.translate(100,100);
        paint.setColor(Color.GREEN);
        canvas.drawRect(rectF,paint);
        //然后繪圖坐標系旋轉20度纽乱,畫黃色的框框
        canvas.rotate(20);
        paint.setColor(Color.YELLOW);
        canvas.drawRect(rectF,paint);

這里我們再次來看一下這個過程蛾绎,首先我們把canvas畫布變成灰色,然后移動畫紅框框迫淹,再移動畫綠框框秘通,再旋轉畫黃色的框框

!敛熬! 我們發(fā)現(xiàn)灰色的部分自始自終都沒有移動肺稀,而我們又通過一系列操作畫了3個不同顏色的框框,說明灰色的坐標系沒有變应民,而畫框框的坐標系一直在改變话原。所以這里再次說明夕吻,canvas自己的坐標系有且只有一個,且唯一不變繁仁,還有一個繪圖坐標系涉馅,他會根據(jù)我們的操作進行相應的偏移.

下面分別看一下其它幾種改變繪圖坐標系的操作代碼

縮放Scale
        RectF r = new RectF(0, 0, 400, 500);
        canvas.drawRect(r, paint);
        paint.setColor(Color.BLUE);
        //sx,sy:分別對x/y方向的一個縮放系數(shù),畫布的縮放會導致里面所有的繪制的東西都會有一個縮放效果
        canvas.scale(1.5f, 0.5f);
        canvas.drawRect(r, paint);*/
斜拉畫布Skew
        RectF r = new RectF(100, 100, 600, 800);
        canvas.drawRect(r, paint);
        paint.setColor(Color.BLUE);
        //sx,sy傾斜度:X軸方向上傾斜60度,tan60=根號3
        canvas.skew(1.73f, 0);
        canvas.drawRect(r, paint);

嗯黄虱,差不多就這樣了

版權聲明:個人原創(chuàng)稚矿,若轉載,請注明出處

+GetTmBean

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末捻浦,一起剝皮案震驚了整個濱河市晤揣,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌朱灿,老刑警劉巖昧识,帶你破解...
    沈念sama閱讀 206,311評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異盗扒,居然都是意外死亡跪楞,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評論 2 382
  • 文/潘曉璐 我一進店門侣灶,熙熙樓的掌柜王于貴愁眉苦臉地迎上來甸祭,“玉大人,你說我怎么就攤上這事炫隶×芤叮” “怎么了?”我有些...
    開封第一講書人閱讀 152,671評論 0 342
  • 文/不壞的土叔 我叫張陵伪阶,是天一觀的道長煞檩。 經(jīng)常有香客問我,道長栅贴,這世上最難降的妖魔是什么斟湃? 我笑而不...
    開封第一講書人閱讀 55,252評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮檐薯,結果婚禮上凝赛,老公的妹妹穿的比我還像新娘。我一直安慰自己坛缕,他們只是感情好墓猎,可當我...
    茶點故事閱讀 64,253評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著赚楚,像睡著了一般毙沾。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上宠页,一...
    開封第一講書人閱讀 49,031評論 1 285
  • 那天左胞,我揣著相機與錄音寇仓,去河邊找鬼。 笑死烤宙,一個胖子當著我的面吹牛遍烦,可吹牛的內容都是我干的。 我是一名探鬼主播躺枕,決...
    沈念sama閱讀 38,340評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼服猪,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了拐云?” 一聲冷哼從身側響起蔓姚,我...
    開封第一講書人閱讀 36,973評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎慨丐,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體泄私,經(jīng)...
    沈念sama閱讀 43,466評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡房揭,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,937評論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了晌端。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片捅暴。...
    茶點故事閱讀 38,039評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖咧纠,靈堂內的尸體忽然破棺而出蓬痒,到底是詐尸還是另有隱情,我是刑警寧澤漆羔,帶...
    沈念sama閱讀 33,701評論 4 323
  • 正文 年R本政府宣布梧奢,位于F島的核電站,受9級特大地震影響演痒,放射性物質發(fā)生泄漏亲轨。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,254評論 3 307
  • 文/蒙蒙 一鸟顺、第九天 我趴在偏房一處隱蔽的房頂上張望惦蚊。 院中可真熱鬧,春花似錦讯嫂、人聲如沸蹦锋。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,259評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽莉掂。三九已至,卻和暖如春渐裸,著一層夾襖步出監(jiān)牢的瞬間巫湘,已是汗流浹背装悲。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留尚氛,地道東北人诀诊。 一個月前我還...
    沈念sama閱讀 45,497評論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像阅嘶,于是被迫代替她去往敵國和親属瓣。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,786評論 2 345

推薦閱讀更多精彩內容