asp.net實現(xiàn)C#繪制太極圖的方法_.Net教程
推薦:Asp.NET調(diào)用百度翻譯的方法這篇文章主要介紹了Asp.NET調(diào)用百度翻譯的方法,是針對百度接口開發(fā)的經(jīng)典實用技巧,非常具有實用價值,需要的朋友可以參考下 本文實例講述了Asp.NET調(diào)用百度翻譯的方法。分享給大家供大家參考。具體分析如下: Asp.NET調(diào)用百度翻譯,如下圖所示: HTML代碼如下: 代碼如下
這篇文章主要介紹了asp.net實現(xiàn)C#繪制太極圖的方法,實例分析了asp.net繪制圖形的技巧,具有一定參考借鑒價值,需要的朋友可以參考下
本文實例講述了asp.net實現(xiàn)C#繪制太極圖的方法。分享給大家供大家參考。具體如下:
成品圖如下所示:
html頁面:
注意設(shè)置:
代碼如下: ContentType="Image/Jpeg"
代碼如下: <%@ Page Language="C#" AutoEventWireup="true" CodeFile="TaiJiTu.aspx.cs" Inherits="TaiJiTu" ContentType="Image/Jpeg" %>
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title></title>
</head>
<body>
<form id="form1" runat="server">
<div>
</div>
</form>
</body>
</html>
后臺代碼:
代碼如下: using System;
using System.Drawing;
using System.Drawing.Drawing2D;
using System.Drawing.Imaging;
public partial class TaiJiTu : System.Web.UI.Page
{
private Encoder myEncoder;
private EncoderParameter myEncoderParameter;
private EncoderParameters myEncoderParameters;
protected void Page_Load(object sender, EventArgs e)
{
int imgWidth = 400; //圖象尺寸
int eyeRadius = imgWidth / 20; //魚眼半徑
int headDiameter = imgWidth / 2; //魚頭直徑
Bitmap image = new Bitmap(imgWidth, imgWidth);
image.SetResolution(300, 300);
Graphics graphics = Graphics.FromImage(image);
//設(shè)置圖像質(zhì)量
graphics.CompositingQuality = CompositingQuality.HighQuality;
graphics.SmoothingMode = SmoothingMode.AntiAlias;
graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;
//底色填充為白色
Brush white = new SolidBrush(Color.White);
graphics.FillRectangle(white, new Rectangle(0, 0, imgWidth, imgWidth));
Brush blue = new SolidBrush(Color.Blue);//定義藍色筆刷
Brush red = new SolidBrush(Color.Red);//定義紅色筆刷
//整個圓形填充藍色
graphics.FillPie(blue, 0, 0, imgWidth, imgWidth, 0, 360);
//定義右邊的路徑(紅色部分)
GraphicsPath redPath = new GraphicsPath();//初始化路徑
redPath.AddArc(0, 0, imgWidth, imgWidth, 0, -180);
redPath.AddArc(0, headDiameter / 2, headDiameter, headDiameter, 0, -180);
redPath.AddArc(headDiameter, headDiameter / 2, headDiameter, headDiameter, 0, 180);
//填充右邊部分
graphics.FillPath(red, redPath);
//填充紅色眼睛
graphics.FillPie(red, new Rectangle(headDiameter / 2 - eyeRadius, headDiameter - eyeRadius, eyeRadius * 2, eyeRadius * 2), 0, 360);
//填充藍色眼睛
graphics.FillPie(blue, new Rectangle(headDiameter + headDiameter / 2 - eyeRadius, headDiameter - eyeRadius, eyeRadius * 2, eyeRadius * 2), 0, 360);
graphics.Dispose();
//寫入到Response輸出流中去,普通質(zhì)量
//image.Save(Response.OutputStream, ImageFormat.Jpeg);
//修改圖片保存質(zhì)量
ImageCodecInfo myImageCodecInfo = GetEncoder(ImageFormat.Jpeg);
myEncoder = Encoder.Quality;
myEncoderParameters = new EncoderParameters(1);
//圖片質(zhì)量等級
myEncoderParameter = new EncoderParameter(myEncoder, 100L);
myEncoderParameters.Param[0] = myEncoderParameter;
//使用指定參數(shù)輸出
image.Save(Response.OutputStream, myImageCodecInfo, myEncoderParameters);
}
private static ImageCodecInfo GetEncoder(ImageFormat format)
{
ImageCodecInfo[] codecs = ImageCodecInfo.GetImageEncoders();
foreach (ImageCodecInfo codec in codecs)
{
if (codec.FormatID == format.Guid)
{
return codec;
}
}
return null;
}
}
希望本文所述對大家的C#程序設(shè)計有所幫助。
分享:Net中實現(xiàn)無限分類的2個例子以前總想著搞這個無限分類,今天終于得空好好的看了下,發(fā)現(xiàn)實現(xiàn)的原理還是很簡單的,數(shù)據(jù)結(jié)構(gòu)上,用兩列(分類編號,上級編號)就可以實現(xiàn),可是為了聯(lián)合查詢的方便,一般都再增加一列(深度),在這個實例里,我只用了兩列,剩下的無非就是遞歸著對TreeView進行數(shù)據(jù)綁定
- Asp.NET調(diào)用百度翻譯的方法
- Net中實現(xiàn)無限分類的2個例子
- .net 實現(xiàn) URL重寫,偽靜態(tài)
- Asp.Net下通過切換CSS換皮膚
- ASP.NET DataTable去掉重復(fù)行的2種方法
- ASP.NET的(HttpModule,HttpHandler)
- 應(yīng)用Response.Write實現(xiàn)帶有進度條的多文件上傳
- asp.net用cookie保存用戶密碼自動登錄
- asp.net如何將后臺c#數(shù)組傳給前臺js?
- VC++根據(jù)explorer.exe進程檢測用戶是否已登錄
- ASP.NET從客戶端中檢測到有潛在危險的request.form值的3種解決方法
- ASP.NET WebForm中%=%>與%#%>的區(qū)別
- 相關(guān)鏈接:
- 教程說明:
.Net教程-asp.net實現(xiàn)C#繪制太極圖的方法
。