制作曲线图

using System;
using System.Collections;
using System.Configuration;
using System.Data;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
//添加画图类
using System.Drawing.Drawing2D;
using System.Drawing.Imaging;
using System.Drawing;
using System.IO;
using System.Data.SqlClient;
using Com.LingHu.Db;

public partial class quxiantu : System.Web.UI.Page
{
    SqlHelper sqlhelper = new SqlHelper();
    protected void Page_Load(object sender, EventArgs e)
    {
        string sql = "";
        string sql1 = "";
        string sql2 = "";
        if (Request.QueryString["type"].ToString() == "体重")
        {
            sql = "select Weight as testValue,Date as testDate from PhysicalExam where userid = ‘" + Session["userid"].ToString() + "‘";
            sql1 = "select min(Weight) as testValue from PhysicalExam where userid = ‘" + Session["userid"].ToString() + "‘";
            sql2 = "select max(Weight) as testValue from PhysicalExam where userid = ‘" + Session["userid"].ToString() + "‘";
        }
        else if (Request.QueryString["type"].ToString() == "体重指数")
        {
            sql = "select BMI as testValue,Date as testDate from PhysicalExam where userid = ‘" + Session["userid"].ToString() + "‘";
            sql1 = "select min(BMI) as testValue from PhysicalExam where userid = ‘" + Session["userid"].ToString() + "‘";
            sql2 = "select max(BMI) as testValue from PhysicalExam where userid = ‘" + Session["userid"].ToString() + "‘";
        }
        else if (Request.QueryString["type"].ToString() == "收缩压")
        {
            sql = "select BPss as testValue,Date as testDate from PhysicalExam where userid = ‘" + Session["userid"].ToString() + "‘";
            sql1 = "select min(BPss) as testValue from PhysicalExam where userid = ‘" + Session["userid"].ToString() + "‘";
            sql2 = "select max(BPss) as testValue from PhysicalExam where userid = ‘" + Session["userid"].ToString() + "‘";
        }
        else if (Request.QueryString["type"].ToString() == "舒张压")
        {
            sql = "select BPsz as testValue,Date as testDate from PhysicalExam where userid = ‘" + Session["userid"].ToString() + "‘";
            sql1 = "select min(BPsz) as testValue from PhysicalExam where userid = ‘" + Session["userid"].ToString() + "‘";
            sql2 = "select max(BPsz) as testValue from PhysicalExam where userid = ‘" + Session["userid"].ToString() + "‘";
        }
        else if (Request.QueryString["type"].ToString() == "体温")
        {
            sql = "select Temperature as testValue,Date as testDate from PhysicalExam where userid = ‘" + Session["userid"].ToString() + "‘";
            sql1 = "select min(Temperature) as testValue from PhysicalExam where userid = ‘" + Session["userid"].ToString() + "‘";
            sql2 = "select max(Temperature) as testValue from PhysicalExam where userid = ‘" + Session["userid"].ToString() + "‘";
        }
        else if (Request.QueryString["type"].ToString() == "空腹血糖")
        {
            sql = "select FPG as testValue,Date as testDate from PhysicalExam where userid = ‘" + Session["userid"].ToString() + "‘";
            sql1 = "select min(FPG) as testValue from PhysicalExam where userid = ‘" + Session["userid"].ToString() + "‘";
            sql2 = "select max(FPG) as testValue from PhysicalExam where userid = ‘" + Session["userid"].ToString() + "‘";
        }
        string min = sqlhelper.GetDataSet(sql1).Tables[0].Rows[0]["testValue"].ToString().Trim();
        string max = sqlhelper.GetDataSet(sql2).Tables[0].Rows[0]["testValue"].ToString().Trim();
        Get_CurveData(sqlhelper.GetDataSet(sql).Tables[0], min, max);
    }
    //获取数据
    public void Get_CurveData(DataTable dt,string minvalue,string maxvalue)
    {
        draw(dt,minvalue,maxvalue);
    }
    public void draw(DataTable dt, string minvalue, string maxvalue)
    {
        //取得记录数量
        int count = dt.Rows.Count;
        //记算图表宽度
        int wd = 80 + 20 * (count - 1);
        //设置最小宽度为800
        if (wd < 600) wd = 600;
        //生成Bitmap对像
        Bitmap img = new Bitmap(wd, 400);
        //生成绘图对像
        Graphics g = Graphics.FromImage(img);
        //定义黑色画笔
        Pen Bp = new Pen(Color.Black);
        //定义红色画笔
        Pen Rp = new Pen(Color.Red);
        //定义银灰色画笔
        Pen Sp = new Pen(Color.Silver);
        //定义大标题字体
        Font Bfont = new Font("Arial", 12, FontStyle.Bold);
        //定义一般字体
        Font font = new Font("Arial", 6);
        //定义大点的字体
        Font Tfont = new Font("Arial", 9);
        //定义横坐标间隔,(最佳值是总宽度-留空宽度[左右侧都需要])/(记录数量-1)
        int xSpace = (wd - 100) / (count - 1);
        //定义纵坐标间隔,不能随便修改,跟高度和横坐标线的条数有关,最佳值=(绘图的高度-上面留空-下面留空)
        int ySpace = 30;
        //纵坐标最大值和间隔值
        int yMaxValue = Convert.ToInt32(maxvalue);
        //绘制底色
        g.DrawRectangle(new Pen(Color.White, 400), 0, 0, img.Width, img.Height);
        //定义黑色过渡型笔刷
        LinearGradientBrush brush = new LinearGradientBrush(new Rectangle(0, 0, img.Width, img.Height), Color.Black, Color.Black, 1.2F, true);
        //定义蓝色过渡型笔刷
        LinearGradientBrush Bluebrush = new LinearGradientBrush(new Rectangle(0, 0, img.Width, img.Height), Color.Blue, Color.Blue, 1.2F, true);
        //绘制大标题
        g.DrawString(Request.QueryString["type"].ToString()+"曲线图", Bfont, brush, 40, 5);
        //绘制信息简报
        string info = " 曲线图生成时间:" + DateTime.Now.ToString();
        g.DrawString(info, Tfont, Bluebrush, 40, 25);
        //绘制图片边框
        g.DrawRectangle(Bp, 0, 0, img.Width - 1, img.Height - 1);
        //绘制竖坐标轴
        g.DrawLine(Bp, 40, 55, 40, 360);
        //绘制横坐标轴 x2的60是右侧空出部分
        g.DrawLine(Bp, 40, 360, 60 + xSpace * (count - 1), 360);
        //绘制竖坐标标题
        g.DrawString(Request.QueryString["type"].ToString(), Tfont, brush, 5, 40);
        //绘制横坐标标题
        g.DrawString("体检时间", Tfont, brush, 40, 385);
        //绘制竖坐标线
        for (int i = 0; i < count; i++)
        {
            g.DrawLine(Sp, 40 + xSpace * i, 60, 40 + xSpace * i, 360);
        }
        //绘制时间轴坐标标签
        for (int i = 0; i < count; i++)
        {
            string st = dt.Rows[i]["testdate"].ToString().Substring(0,10);
            g.DrawString(st, font, brush, 30 + xSpace * i, 370);
        }
        //绘制横坐标线
        for (int i = 0; i < 10; i++)
        {
            g.DrawLine(Sp, 40, 60 + ySpace * i, 40 + xSpace * (count - 1), 60 + ySpace * i);
            if (yMaxValue % 10 == 0)
            {
                //横坐标轴的值间隔是最大值除以间隔数
                int s = yMaxValue - i * (yMaxValue / 10);
                //绘制发送量轴坐标标签
                g.DrawString(s.ToString(), font, brush, 10, 60 + ySpace * i);
            }
            else
            {
                //横坐标轴的值间隔是最大值除以间隔数
                double s = Convert.ToDouble(yMaxValue) - Convert.ToDouble(i) * (Convert.ToDouble(yMaxValue) / Convert.ToDouble(10));
                //绘制发送量轴坐标标签
                g.DrawString(s.ToString(), font, brush, 10, 60 + ySpace * i);
            }
        }
        //定义纵坐标单位数值=纵坐标最大值/标量最大值(360/yMaxValue*1.2)
        double yAveValue = Convert.ToDouble(360) / Convert.ToDouble(yMaxValue*1.2);
        //定义曲线转折点
        Point[] p = new Point[count];
        for (int i = 0; i < count; i++)
        {
            p[i].X = 40 + xSpace * i;
            p[i].Y = Convert.ToInt32(Convert.ToDouble(360) - Convert.ToDouble(dt.Rows[i]["testvalue"]) * Convert.ToDouble(yAveValue));
        }
        //绘制折线图
        //g.DrawLines(Rp, p);
        //绘制曲线图
        //g.DrawCurve(Rp, p);
        //绘制自定义张力的曲线图(0.5F是张力值,默认就是这个值)
        g.DrawCurve(Rp, p, 0.5F);
        //当需要在一个图里绘制多条曲线的时候,就多定义个point数组,然后画出来就可以了。
        for (int i = 0; i < count; i++)
        {
            //绘制发送记录点的发送量
            g.DrawString(dt.Rows[i]["testvalue"].ToString(), font, Bluebrush, p[i].X, p[i].Y - 10);
            //绘制发送记录点
            g.DrawRectangle(Rp, p[i].X - 1, p[i].Y - 1, 2, 2);
        }
        //保存绘制的图片
        MemoryStream stream = new MemoryStream();
        img.Save(stream, ImageFormat.Jpeg);
        //图片输出
        System.Web.HttpContext.Current.Response.Clear();
        System.Web.HttpContext.Current.Response.ContentType = "image/jpeg";
        System.Web.HttpContext.Current.Response.BinaryWrite(stream.ToArray());
    }
}

制作曲线图,布布扣,bubuko.com

时间: 2024-12-17 10:44:41

制作曲线图的相关文章

Delphi中的TChart使用用法

1.TChart Hello world 放一个控件到窗体上,然后写代码加入一个折线数据序列: var Series: TLineSeries; begin Series := TLineSeries.Create(Chart1); Series.Add(100, '头部', clRed); Series.Add(200, '颈部', clGreen); Chart1.AddSeries(Series); end; 这样就会生成一个简单的折线图表,要生成其它类型的数据图表,可以添加不同的数据序列

Excel2007制作直方图和正态分布曲线图

对同一维度的数据分析数据分布范围及分布趋势,要通过制作直方图和正态分布曲线图体现. 例如:已知所有员工的日收入,分析员工收入分布情况(51.7,50.6,57.9,56.9,56.7,56.7,55.3,56.1,53.7,54.5,56.9,51.9,52.1,55.1,54.9,54.7,55.3,55.3,54.5,54.9,54.5,55.3,54.9,54.3,53.7,53.5,53.7,53.1,54.5,53.1,53.9,53.5,53.3,53.9,53.5,53.5,52.

比较不错的JS 曲线图

fashion chart   falsh文件支持,无需考虑兼容 Highcharts(纯JS,很漂亮 效果很好) Highcharts是一个制作图表的纯Javascript类库,主要特性如下: 兼容性:兼容当今所有的浏览器,包括iPhone.IE和火狐等等: 对个人用户完全免费: 纯JS,无BS: 支持大部分的图表类型:直线图,曲线图.区域图.区域曲线图.柱状图.饼装图.散布图: 跨语言:不管是PHP.Asp.net还是Java都可以使用,它只需要三个文件:一个是Highcharts的核心文件

Highcharts是一个制作图表的纯Javascript类库

Highcharts是一个制作图表的纯Javascript类库,主要特性如下: 兼容性:兼容当今所有的浏览器,包括iPhone.IE和火狐等等: 对个人用户完全免费: 纯JS,无BS: 支持大部分的图表类型:直线图,曲线图.区域图.区域曲线图.柱状图.饼装图.散布图: 跨语言:不管是PHP.Asp.net还是Java都可以使用,它只需要三个文件:一个是Highcharts的核心文件highcharts.js,还有a canvas emulator for IE和Jquery类库或者MooTool

[转]一些实用的图表Chart制作工具

最近工作过程中需要用到前端一些JS框架,看到一篇博文就转过来备份使用,后续会再完善一些材料. Flot Flot一个纯javascript绘画库,基于jQuery开发.它能够在客户端根据任何数据集快速生成图片.目前只能绘制线状图和柱状. JQchart 基于Canvas+jQuery,可拖放/交互的简单图形控件. Open Flash Chart Open Flash Chart是一个开源的Flash制图组件. PlotKit PlotKit是一个纯javascript绘图工具包.它支持HTML

使用chart和echarts制作图表

  前  言 chart.js是一个简单.面向对象.为设计者和开发者准备的图表绘制工具库.它可以帮你用不同的方式让你的数据变得可视化.每种类型的图表都有动画效果,并且看上去非常棒,即便是在retina屏幕上.Chart.js基于HTML5 canvas技术,支持所有现代浏览器,并且针对IE7/8提供了降级替代方案.并且它不依赖任何外部工具库,轻量级(压缩之后仅有4.5k),并且提供了加载外部参数的方法. ECharts,一个纯 Javascript 的图表库,可以流畅的运行在 PC 和移动设备上

网站搭建 (第11天) 阅读量曲线图

一.前言 为了让自己能直观的看出博客阅读量的变化,而不需要到后台观察,所以就使用了Highcharts的基础折线图来帮助实现.其文档地址:Highcharts 演示. 样例效果: 通过阅读API文档,可以实现自己想要的样式,也可以改变线条的颜色.一系列的配置主要有chart: {图表配置},colors: [颜色集合],credits: {版权信息},data: {数据功能模块},drilldown: {钻取},exporting: {导出},labels: {标签},legend: {图例},

nCompass-如何制作报告

单击返回:自学N-Compass之路  nCompass-如何制作数据报告 什么是数据报告: 统计运维人员关心的历史数据,并且能够定期生成报告发给运维人员,报告内容主要以应用类和链路类的内容位置. 如果以时间划分: 时报,日报,周报,以及一次性报告. 数据报告三大分类: 我的报告 报告模板(系统默认自带) 分享给我的报告(其他用户创建并分享给我的报告) 报告的两大组成部分: 封面:报告的首页,通常是LOGO.文字.时间等元素. 大纲:报告的内容 1.   设计报告封面 1.1  封面模板的设计

怎么制作室内720全景?

水平720度全能观看的场景图片,720度全景从专业的角度来讲就是视角逾越人的正常视角的图像.可以看到天和地的图片.那么,720度VR室内全景效果图怎么做呢? 室内全景如何拍摄 越来越多的行业在应用着360全景展示.所以,随着科技的发展.现在有很多的企业在网站中添加网展公司制作的360全景展示.小编原来讲过如何在室外拍摄全景,今天就教下大家如何在室内拍摄出好看的全景照片: 一.光线 想其艺术性要求不高,如何利用有限的光线是室内拍摄最具挑战性的难点.由于室内光源是固定的补光除外)也是不可撑控的唯一能