C#winform端SunnyUI之uiLineChart

1 添加数据

[Description("生成数据")]
private void ResetData()
{
    uiLineChart1.Option.Clear();
    for (int i = 0; i < 4; i++)
    {
        var pointX = new List<double>();
        var pointY = new List<double>();
        for (int j = 0; j < 100; j++)
        {
            pointX.Add(j);
            pointY.Add(i + Math.Sin(j / 100.0 * (Math.PI * 2 * 4)));
        }
        AddChartData($"线条:{i}", pointX.ToArray(), pointY.ToArray());
    }
    SetChartLineStyle();
}

/// <summary>
/// 向图标添加数据
/// </summary>
/// <param name="name">线条名称</param>
/// <param name="arrx">横轴数据</param>
/// <param name="arry">纵轴数据</param>
private void AddChartData(string name, double[] arrx, double[] arry)
{
    var line = new UILineSeries(name);
    line.XData.AddRange(arrx);
    line.YData.AddRange(arry);
    uiLineChart1.Option.AddSeries(line);
}


2 设置样式

[Description("设置ChartLineStyle")]
private void SetChartLineStyle()
{
    /**
     *    添加数据
     *    var line = new UILineSeries(name);
     *    line.XData.AddRange(arrx);//double[]
          line.YData.AddRange(arry);//double[]
     *    uiLineChart1.Option.AddSeries(line);
     */

    uiLineChart1.Option.ShowZeroLine = false;
    uiLineChart1.Option.ShowZeroValue = false;
    uiLineChart1.Option.XAxis.Clear();

    var uiTitle = new UITitle { Text = "图表一", SubText = "正玄波" };
    uiLineChart1.Option.Title = uiTitle;//设置图表名称

    uiLineChart1.Option.XAxis.Name = "时间";//横轴名称
    uiLineChart1.Option.YAxis.Name = "金钱1";//纵轴名称
    uiLineChart1.Option.Y2Axis.Name = "金钱2";//纵轴名称

    uiLineChart1.Option.XAxis.ShowGridLine = true;//横轴网格线
    uiLineChart1.Option.YAxis.ShowGridLine = true;//纵轴网格线


    //uiLineChart1.Option.XAxisType = UIAxisType.Value;//横轴类型
    //uiLineChart1.Option.XAxis.SetRange(DateTime.Now, DateTime.Now.AddMinutes(10));//设置横轴时间范围
    uiLineChart1.Option.XAxisType = UIAxisType.Value;//横轴类型

    float xMin, xMax, yMin, yMax;
    GetAxisRange(true, out xMin, out xMax);
    GetAxisRange(false, out yMin, out yMax);
    uiLineChart1.Option.XAxis.SetRange(xMin, xMax);//设置横轴范围(1.类型为时间时需要设置时间范围;2.可通过改属性重置图表显示)
    uiLineChart1.Option.YAxis.SetRange(yMin, yMax);//设置横轴范围(1.类型为时间时需要设置时间范围;2.可通过改属性重置图表显示)

    uiLineChart1.Refresh();

}

3 获取坐标轴的最大最小值

/// <summary>
/// 获取轴系范围
/// </summary>
/// <param name="isXAxis">是否为X轴</param>
/// <param name="min">最大值</param>
/// <param name="max">最小值</param>
private void GetAxisRange(bool isXAxis, out float min, out float max)
{
    min = isXAxis ? 0 : -10;
    max = isXAxis ? 100 : 10;
    if (uiLineChart1.Option.Series.Count < 1) return;

    var name = uiLineChart1.Option.Series.ElementAt(0).Key;
    double tempMin, tempMax;
    if (isXAxis)
    {
        tempMin = uiLineChart1.Option.Series[name].XData.Min();
        tempMax = uiLineChart1.Option.Series[name].XData.Max();
        for (int i = 1; i < uiLineChart1.Option.Series.Count; i++)
        {
            name = uiLineChart1.Option.Series.ElementAt(i).Key;
            tempMin = Math.Min(uiLineChart1.Option.Series[name].XData.Min(), tempMin);
            tempMax = Math.Max(uiLineChart1.Option.Series[name].XData.Max(), tempMax);
        }
    }
    else
    {
        tempMin = uiLineChart1.Option.Series[name].YData.Min();
        tempMax = uiLineChart1.Option.Series[name].YData.Max();
        for (int i = 1; i < uiLineChart1.Option.Series.Count; i++)
        {
            name = uiLineChart1.Option.Series.ElementAt(i).Key;
            tempMin = Math.Min(uiLineChart1.Option.Series[name].YData.Min(), tempMin);
            tempMax = Math.Max(uiLineChart1.Option.Series[name].YData.Max(), tempMax);
        }
        double dReservedValue = (tempMax - tempMin) * 0.2;//上下预留1/5
        tempMin -= dReservedValue;
        tempMax += dReservedValue;
    }
    min = (float)tempMin;
    max = (float)tempMax;
}

  • 1
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
SunnyUI.Net 是基于.Net Framework 4.0+、.Net Core3.1、.Net 5 框架的 C# WinForm 开源控件库、工具类库、扩展类库、多页面开发框架。 源码编译环境:VS2019 16.8+,.Net5,.Net Core3.1 动态库应用环境:VS2010及以上,.Net Framework 4.0及以上(不包括.Net Framework 4 Client Profile),.Net Core 3.1,.Net 5.0 推荐通过Nuget安装:Install-Package SunnyUI,或者通过Nuget搜索SunnyUI安装。 软件介绍: 1、开源控件库 基于.Net Framework4.0,原生控件开发,参考 Element主题风格,包含 按钮、编辑框、下拉框、数据表格、工控仪表、统计图表在内的常用控件超过 50 个,满足常规开发需求,每个控件都精雕细琢,注重细节; 包含 Element 风格主题 11 个,其他主题 6 个,包含主题管理组件 UIStyleManager,可自由切换主题。 2、工具库 收集整理开发过程中经常用到的工具类库。 3、扩展库 收集整理开发过程中经常用到的扩展类库。 4、多页面框架 参考Element,包括7种常用框架风格,只需几行简单的代码即可创建多页面程序,其支撑组件包括UIForm,UIPage,UIFrame,集合常用控件库即可快速开发WinForm应用程序。 SunnyUI.Net开发框架 更新日志: v3.0.2 UIMarkLabel:增加带颜色标签的Label UIRoundProcess:圆形滚动条 UIBreadcrumb:增加面包屑导航 UILedLabel:增加Led标签 UIHeaderButton:在工具箱中显示 UILineChart:支持拖拽选取放大 UIDateTimePicker:修复下拉选择日期后关闭的Bug UINavMenu:增加设置二级菜单底色 UIColorPicker:增加单击事件以选中颜色 UITitlePage:增加ShowTitle可控制是否显示标题 UINavBar:增加可设置背景图片 框架增加IFrame接口,方便页面跳转 UIDataGridView:修改垂直滚动条和原版一致,并增加翻页方式滚动 UIPagination: 修正因两次查询数量相等而引起的不刷新 UIHeaderButton: 增加字体图标背景时鼠标移上背景色 UITabControl:修改第一个TabPage关不掉的Bug UIDataGridView:增加EnterAsTab属性,编辑输入时,用Enter键代替Tab键跳到下一个单元格 UILineChart:增加鼠标框选放大,可多次放大,右键点击恢复一次,双击恢复 UITitlePanel:修复OnMouseMove事件 UITrackBar:增加垂直显示方式 UIFlowLayoutPanel:修改了一处因为其加入控件大小发生变化而引起的滚动条出错。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值