您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關(guān)C#中畫圖模式與縮放功能的命令怎么寫,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
在實體建模軟件中,經(jīng)常有設(shè)置并保存各種參考坐標系的功能,方便建立模型。C#畫圖中也有這種類似功能。不過沒有建模軟件那么強大。實體建模軟件中,可以獨立的設(shè)置并保存各種坐標系,并隨時調(diào)用。而這里只能以嵌套的形式調(diào)用,當返回到上一級狀態(tài)時,跳過的狀態(tài)就不再保存了。
C#畫圖普通模式主要命令:
state = graphics.BeginContainer(); 建一個新繪圖狀態(tài) e.Graphics.EndContainer(state1); 結(jié)束這個繪圖狀態(tài) Rectangle rect = new Rectangle(0, 0, 100, 100);//示例圖形 GraphicsContainer state1 = e.Graphics.BeginContainer(); //建一個新繪圖坐標state1 e.Graphics.TranslateTransform(100, 100); //移動坐標系到100,100,畫藍色矩形標記 e.Graphics.DrawRectangle(Pens.Blue, rect); GraphicsContainer state2 = e.Graphics.BeginContainer(); //在此基礎(chǔ)上建一個繪圖坐標state2 e.Graphics.RotateTransform(45);//旋轉(zhuǎn)45度, 畫紅色矩形標記 e.Graphics.DrawRectangle(Pens.Red, rect); e.Graphics.TranslateTransform(100, 100); e.Graphics.DrawRectangle(Pens.Black, rect); e.Graphics.EndContainer(state2);//退出坐標系2, 畫藍橢圓 e.Graphics.DrawEllipse(Pens.Blue, rect); e.Graphics.EndContainer(state1);//退出state1, 畫紅橢圓 e.Graphics.DrawRectangle(Pens.Red, rect);
建立狀態(tài)1
移動到100,100,畫藍色矩形
建被嵌套的狀態(tài)2
移動到200,0,畫紅色矩形
退出狀態(tài)2,畫藍色橢圓
退出狀態(tài)1,畫紅色矩形
狀態(tài)2是被嵌套的,如果直接退出狀態(tài)1畫紅色矩形,狀態(tài)2不再被保存。
graphics.BeginContainer()和EndGontainer是保存和返回當前畫板狀態(tài),當然,移動只是一種改變畫板狀態(tài)的方式。
C#畫圖縮放功能主要命令:
GraphicsContainercontainerState= e.Graphics.BeginContainer( destRect,srcRect, GraphicsUnit.Pixel); 多加兩個參數(shù),destRect和scrRect制定縮放大小 Pixel指定單位 RectanglesrcRect=newRectangle( 0,0,200,200); RectangledestRect=newRectangle( 200,200,100,100); //建一個比例縮放的畫圖板. GraphicsContainercontainerState= e.Graphics.BeginContainer( destRect,srcRect, GraphicsUnit.Pixel); //繪圖縮放綠矩形. e.Graphics.FillRectangle( newSolidBrush(Color.Red),0,0,100,100); //退出此繪圖板. e.Graphics.EndContainer(containerState); //繪原始紅矩形. e.Graphics.FillRectangle( newSolidBrush(Color.Green),0,0,100,100);
關(guān)于“C#中畫圖模式與縮放功能的命令怎么寫”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。