c#用Gnuplot画图源码

直接调用这个类即可,需要下载个GnuPlot安装下。

复制代码
// Author: Leonardo Tazzini

using System;
using System.Diagnostics;
using System.Drawing;
using System.IO;
using System.Windows.Forms;

/// <summary>
/// Tested with Gnuplot 5.2
/// </summary>
public class GnuPlot
{
    public GnuPlot()
    {
        // Default path for gnuplot
        this.Path = System.IO.Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.ProgramFiles), "gnuplot\\bin\\gnuplot.exe");
        // TODO: Check if path is valid
    }

    public GnuPlot(string path)
    {
        this.Path = path;
    }

    /// <summary>
    /// Path of gnuplot.exe
    /// </summary>
    public string Path { get; set; }

    /// <summary>
    /// Graph input CSV with GnuPlot. NumWaves is the number of channels to draw. If imageOut a PNG image is saved into out.png and displayed. 
    /// </summary>
    public void DrawGraph(string csvFileName, int numWaves, bool generatePngImage = true)
    {
        // gnuplot.exe not found
        if(!File.Exists(Path))
        {
            MessageBox.Show("gnuplot.exe not found. Please check the path.");
            return;
        }

        var gnuPlot = new Process();
        gnuPlot.StartInfo.FileName = Path;
        gnuPlot.StartInfo.CreateNoWindow = true;
        gnuPlot.StartInfo.UseShellExecute = false;
        gnuPlot.StartInfo.RedirectStandardInput = true;
        gnuPlot.Start();

        StreamWriter gnuPlotSw = gnuPlot.StandardInput;
        if (generatePngImage)
        {
            // TODO: Remove dependency from Windows Forms
            Rectangle bounds = Screen.PrimaryScreen.WorkingArea;
            gnuPlotSw.WriteLine("set terminal png size " + (bounds.Width * 0.9) + "," + (bounds.Height * 0.8));
            gnuPlotSw.WriteLine("set out 'out.png'");
        }
        gnuPlotSw.WriteLine("set style data lines");      //linespoints
        gnuPlotSw.WriteLine("set datafile separator ';'");
        //gnuPlotSw.WriteLine("set decimalsign locale; set decimalsign ','");
        gnuPlotSw.WriteLine("set xlabel 'time  (s)'");
        gnuPlotSw.WriteLine("set ylabel 'value (v)'");
        gnuPlotSw.WriteLine("set grid");
        //gnuPlotSw.WriteLine("set xtics 0,0.5");
        //gnuPlotSw.WriteLine("set ytics 0,5");

        // TODO: evaluate add "every .." to gnuplot cmd line    
        gnuPlotSw.Write("plot '" + System.IO.Path.GetFullPath(csvFileName) + "' using 1:2 title 'CH1'");
        if (numWaves == 2)
            gnuPlotSw.WriteLine(", '' using 1:3 title 'CH2'");
        else
            gnuPlotSw.Write("\n");
        gnuPlotSw.Flush();
        if (generatePngImage)
        {
            gnuPlotSw.WriteLine("exit");
            gnuPlotSw.Flush();
            gnuPlot.WaitForExit();
            Process.Start("out.png");
        }
        gnuPlot.Close();
    }


}

读吧数据存为csv,传入DrawGraph即可;数据如下:

TIME(s);CH1(v);

-600.99999949;1.5001;

-599.99999949;-0.0598999999999998;

-598.99999949;-0.0398999999999998;

-597.99999949;-0.0398999999999998;

-596.99999949;-0.0398999999999998;

-595.99999949;-0.0398999999999998;

-594.99999949;-0.0398999999999998;

-593.99999949;-0.0398999999999998;

-592.99999949;-0.0598999999999998;

-591.99999949;-0.0398999999999998;

-590.99999949;-0.0398999999999998;

-589.99999949;-0.0598999999999998;

-588.99999949;-0.0398999999999998;

-587.99999949;-0.0398999999999998;

-586.99999949;-0.0398999999999998;

-585.99999949;-0.0598999999999998;

显示示意:

相关推荐
charlie1145141918 分钟前
嵌入式C++工程实践第16篇:第四次重构 —— LED模板,从通用GPIO到专用抽象
c语言·开发语言·c++·驱动开发·嵌入式硬件·重构
故事和你9114 分钟前
洛谷-数据结构1-4-图的基本应用1
开发语言·数据结构·算法·深度优先·动态规划·图论
程序猿编码1 小时前
给你的网络流量穿件“隐形衣“:手把手教你用对称加密打造透明安全隧道
linux·开发语言·网络·安全·linux内核
aq55356002 小时前
编程语言三巨头:汇编、C++与PHP大比拼
java·开发语言
aq55356002 小时前
PHP vs Python:30秒看懂核心区别
开发语言·python·php
我是无敌小恐龙2 小时前
Java SE 零基础入门Day01 超详细笔记(开发前言+环境搭建+基础语法)
java·开发语言·人工智能·opencv·spring·机器学习
码云数智-大飞3 小时前
零基础微信小程序制作平台哪个好
开发语言
神仙别闹3 小时前
基于 MATLAB 实现的 DCT 域的信息隐藏
开发语言·matlab
techdashen3 小时前
Go 标准库 JSON 包迎来重大升级:encoding/json/v2 实验版来了
开发语言·golang·json
.千余3 小时前
【Linux】基本指令3
linux·服务器·开发语言·学习