Winform中设置ZedGraph当前所有曲线的颜色
场景
Winforn中设置ZedGraph曲线图的属性、坐标轴属性、刻度属性:
https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/100112573
当ZedGraph的图形渲染完成后,添加设置所有曲线颜色功能。
注:
博客主页:
https://blog.csdn.net/badao_liumang_qizhi
关注公众号
霸道的程序猿
获取编程相关电子书、教程推送与免费下载。
实现
首先在ZedGraph的右键菜单中添加设置曲线颜色选项,在面板初始化的方法中订阅右键事件。
zgc.ContextMenuBuilder -= zgc_ContextMenuBuilder; //上下文菜单生成事件订阅
zgc.ContextMenuBuilder += zgc_ContextMenuBuilder; //上下文菜单生成事件订阅
然后在订阅的方法中
private static void zgc_ContextMenuBuilder(ZedGraphControl control, ContextMenuStrip menuStrip, Point mousePt, ZedGraphControl.ContextMenuObjectState objState)
{
#region 扩展上下文菜单 #region 图形选项菜单 ToolStripMenuItem mnuChartOption = new ToolStripMenuItem(); //新建菜单项对象
mnuChartOption.Name = "set_curve_color";
mnuChartOption.Text = "设置曲线颜色";
//点击弹出图形选项对话框
mnuChartOption.Click += delegate(object sender, EventArgs e)
{
if (curveModelList == null || curveModelList.Count == )
{
XtraMessageBox.Show("当前没有曲线");
}
else
{
FrmSetCurveColor setCurveColor = new FrmSetCurveColor();
DialogResult result = setCurveColor.ShowDialog(); //显示Dialog
if (result == DialogResult.OK)
{
TriggerSetCurveColor();
XtraMessageBox.Show("设置曲线颜色成功");
}
}
};
menuStrip.Items.Add(mnuChartOption); //把图形选项对话框添加到上下文菜单中 #endregion #endregion #region 汉化上下文菜单中的菜单项 foreach (ToolStripMenuItem item in menuStrip.Items)
{
switch (item.Name)
{
case "copied_to_clip":
item.Text = @"复制到剪贴板";
break;
case "copy":
item.Text = @"复制";
break;
case "page_setup":
item.Text = @"页面设置...";
break;
case "print":
item.Text = @"打印...";
break;
case "save_as":
item.Text = @"另存图表...";
break;
case "set_default":
item.Text = @"恢复默认大小";
break;
case "show_val":
item.Text = @"显示节点数值";
break;
case "title_def":
item.Text = @"标题";
break;
case "undo_all":
item.Text = @"还原所有缩放";
break;
case "unpan":
item.Text = @"还原上一步缩放";
break;
case "unzoom":
item.Text = @"还原缩放";
break;
case "set_curve_color":
item.Text = @"设置曲线颜色";
break;
} } #endregion }
此时会汉化右键菜单并添加右键选项,并且其点击事件是打开设置曲线颜色面板。
在设置曲线颜色面板的代码中,在其load方法中调用初始化面板的方法,
此时要根据传递的曲线的Model的list去生成当前已有曲线的设置的panel。
那么当前已经有多少个曲线是如何传递的?
在前面ZedGraph生成曲线的地方所在的工具类中声明一个全局的list
public static List<CurveModel> curveModelList= new List<CurveModel>();
其中CurveModel是自定义的存取曲线属性的Model类
public class CurveModel
{
/// <summary>
/// 曲线序号
/// </summary>
private int curveIndex; public int CurveIndex
{
get { return curveIndex; }
set { curveIndex = value; } } /// <summary>
/// 源文件
/// </summary>
private string originFile; public string OriginFile
{
get { return originFile; }
set { originFile = value; } } /// <summary>
/// 源文件完整路径
/// </summary>
private string originFileFullPath; public string OriginFileFullPath
{
get { return originFileFullPath; }
set { originFileFullPath = value; } } /// <summary>
/// 属性名
/// </summary>
private string attributeName; public string AttributeName
{
get { return attributeName; }
set { attributeName = value; } } /// <summary>
/// 颜色
/// </summary>
private string color; public string Color
{
get { return color; }
set { color = value; }
} }
声明完list后,其中生成曲线的地方也在这个工具类中
curveModelList.Clear(); int curveIndex = ;
for (int k = ; k < compTestDataList.Count; k++)
{
//循环添加曲线
for (int i = ; i < yList.Count; i++)
{
SymbolType symbolType = GetCurveSimple(yList[i].CurveType); //根据配置文件中曲线符号类型返回曲线符号标识
list = SetCurveText(interval, xAttribute.TitleKey, yList[i].TitleKey, compTestDataList[k]);
LineItem myCurve = myPane.AddCurve(yList[i].Title, list, System.Drawing.ColorTranslator.FromHtml(yList[i].Color), symbolType);
myCurve = SetCurveType(myCurve,symbolType, yList[i].Type, yList[i].Color); //根据配置文件设置曲线类型
myCurve.YAxisIndex = i; //很关键,对应使用那个坐标值
CurveModel curveModel = new CurveModel();
string originFile = compTestDataList[k].ThisDataFile;
curveModel.OriginFile = originFile.Substring(originFile.LastIndexOf("\\") + );
curveModel.CurveIndex = curveIndex;
curveModel.OriginFileFullPath = originFile;
curveModel.AttributeName = yList[i].Title;
curveModel.Color = yList[i].Color;
curveModelList.Add(curveModel);
curveIndex++;
}
}
这样在生成曲线时就将当前图形的所有曲线的属性存到一个工具类中全局的一个list中,然后在设置曲线颜色面板中获取这个list。
private void FrmSetCurveColor_Load(object sender, EventArgs e)
{
curveModelList.Clear();
curveModelList = ChartCompareHelper.curveModelList;
initSetCurveColorPane(curveModelList); }
然后在使用这个list去初始化设置颜色的面板
private void initSetCurveColorPane(List<CurveModel> curveModelList)
{
int panelControlHeight = ;
int panelControlWidth = ;
foreach(CurveModel curve in curveModelList)
{
PanelControl panelControl = new PanelControl();
#region 生成一个Label标识X轴
//生成一个Label标识X轴
LabelControl label = new LabelControl();
label.Text = "第" + (curve.CurveIndex + ).ToString() + "条曲线(" + curve.OriginFile + "的" + curve.AttributeName + ")的颜色为:";
label.Location = new Point(Global.NOGROUP_HORIZONTAL_DISTANCE, Global.GROUP_VERTICAL_DISTANCE);
label.Parent = panelControl;
#endregion #region 生成一个颜色选择器 //添加颜色选择器
ColorEdit colorEditX = new ColorEdit();
colorEditX.Text = curve.Color;
colorEditX.Width = Global.CHART_OPTION_WIDTH;
colorEditX.Location = new Point(Global.NOGROUP_HORIZONTAL_DISTANCE * + label.Width, Global.GROUP_VERTICAL_DISTANCE);
colorEditX.Parent = panelControl;
colorEditX.Name = "colorEdit"+curve.CurveIndex; #endregion #region 设置X轴Panel的位置以及属性 //设置panel的宽度
panelControl.Width = label.Width + colorEditX.Width + Global.NOGROUP_HORIZONTAL_DISTANCE * ;
//设置panel的高度
panelControl.Height = label.Height + Global.GROUP_VERTICAL_DISTANCE * ;
panelControlHeight = panelControl.Height;
panelControlWidth = panelControl.Width;
//设置panel的位置
panelControl.Location = new Point(Global.NOGROUP_HORIZONTAL_DISTANCE, (panelControl.Height * curve.CurveIndex) + (Global.GROUP_VERTICAL_DISTANCE *(curve.CurveIndex + )));
//设置Name
panelControl.Name = "panelControl" + curve.CurveIndex;
//将panel添加到当前窗体
this.Controls.Add(panelControl); #endregion
} this.Width = panelControlWidth + Global.NOGROUP_HORIZONTAL_DISTANCE * ; this.Height = (curveModelList.Count + ) * panelControlHeight + (curveModelList.Count + ) * Global.GROUP_VERTICAL_DISTANCE + +this.panelControl1.Height;
}
然后设置颜色后,点击保存后在确定按钮的点击事件中
private void simpleButton2_Click_1(object sender, EventArgs e)
{
for (int i = ; i < curveModelList.Count; i++)
{
ColorEdit colorEditY = this.Controls.Find("colorEdit" + i, true)[] as ColorEdit;
curveModelList[i].Color = colorEditY.Text;
} this.DialogResult = System.Windows.Forms.DialogResult.OK;
}
再将设置的颜色属性赋值给当前设置颜色面板作用域的list
List<CurveModel> curveModelList = new List<CurveModel>();
此时窗体返回OK,再回到右键打开窗口的地方
if (result == DialogResult.OK)
{
TriggerSetCurveColor();
XtraMessageBox.Show("设置曲线颜色成功");
}
此时会触发设置曲线颜色的方法
public static void TriggerSetCurveColor()
{
if (OnSetCurveColor != null)
{
OnSetCurveColor(null, System.EventArgs.Empty);
} }
此事件声明
public static event EventHandler OnSetCurveColor;
事件会在图形所在的页面进行订阅
ChartCompareHelper.OnSetCurveColor + = ChartCompareHelper_OnSetCurveColor;
订阅执行的方法
private void ChartCompareHelper_OnSetCurveColor(object sender, EventArgs e)
{
ChartCompareHelper.SetCurveColor(this.zedGraphControl1); }
此方法传递当前ZedGraph对象
public static void SetCurveColor(ZedGraphControl zedGraphControl)
{
for (int i = ; i < curveModelList.Count;i++)
{
zedGraphControl.GraphPane.CurveList[i].Color = System.Drawing.ColorTranslator.FromHtml(curveModelList[i].Color);
} zedGraphControl.GraphPane.AxisChange();
zedGraphControl.Refresh(); zedGraphControl.Invalidate(); }
然后按顺序设置曲线颜色。
Winform中设置ZedGraph当前所有曲线的颜色的更多相关文章
- Winform中设置ZedGraph鼠标悬浮显示举例最近曲线上的点的坐标值和X轴与Y轴的标题
场景 Winform中设置ZedGraph鼠标双击获取距离最近曲线上的点的坐标值: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/ ...
- Winform中设置ZedGraph的曲线为散点图
场景 Winform中设置ZedGraph的曲线符号Symbol以及对应关系: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/10 ...
- Winform中设置ZedGraph的曲线为折线、点折线、散点图
场景 Winform中设置ZedGraph的曲线为散点图: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/102465399 在上 ...
- Winform中设置ZedGraph多条Y轴时与多条曲线一一对应
场景 Winform中实现ZedGraph的多条Y轴(附源码下载): https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/1001322 ...
- Winform中设置ZedGraph的曲线符号Symbol以及对应关系
场景 Winforn中设置ZedGraph曲线图的属性.坐标轴属性.刻度属性: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/10 ...
- Winform中设置ZedGraph鼠标双击获取距离最近曲线上的点的坐标值
场景 WInforn中设置ZedGraph的焦点显示坐标格式化以及显示三个坐标数的解决办法: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/det ...
- Winform中设置ZedGraph的X轴的刻度根据曲线获取
场景 Winforn中设置ZedGraph曲线图的属性.坐标轴属性.刻度属性: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/10 ...
- Winform中设置ZedGraph鼠标滚轮缩放的灵敏度以及设置滚轮缩放的方式(鼠标焦点为中心还是图形中心点)
场景 Winforn中设置ZedGraph曲线图的属性.坐标轴属性.刻度属性: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/10 ...
- Winform中设置ZedGraph多条Y轴时坐标轴左右显示设置
场景 Winform中实现ZedGraph的多条Y轴(附源码下载): https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/1001322 ...
随机推荐
- python库的tkinter带你进入GUI世界(计算器简单功能)
前言 文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者: 一个处女座的程序猿 PS:如有需要Python学习资料的小伙伴可以加 ...
- python数据可视化简介(一)
目录 一:配置jupyter notebook 二:Matplotlib图像实例 数据可视化是用图形或者表格的形式进行数据显示,用图形化的手段,清晰有效地传递与沟通信息.既要保证直观易分析,又要保 ...
- Java生鲜电商平台-App系统架构开发与设计
Java生鲜电商平台-App系统架构开发与设计 说明:阅读此文,你可以学习到以下的技术分享 1.Java生鲜电商平台-App架构设计经验谈:接口的设计2.Java生鲜电商平台-App架构设计经验谈:技 ...
- 从《华为的冬天》到AI的冬天 | 甲子光年
知难不难,惶者生存. 作者 | DougLong 编辑 | 火柴Q.甲小姐 *本文为甲子光年专栏作家DougLong独家稿件.作者为AI从业者.Gary Marcus<Rebooting AI& ...
- Android 布局测试
wrap_content <Button android:id="@+id/button1" android:layout_width="wrap_content& ...
- 打开Visual Studio 2017报错:未能正确加载“VSTS for Database Professionals Sql Server Data-tier Application”包
出现如下错误 解决办法 > cmd > regsvr32 %windir%\system32\jscript.dll
- 【亲测有效】Ubuntu18.04 sudo apt update无法解析域名的解决方案
问题描述如下: 拿起了封尘已久的ThinkPad,输入 sudo apt update 的时候,发现这个命令变得不好使了,具体出现的问题如下图所示: #( 09/08/19@ 2:44下午 )( py ...
- 事务的四大性质:ACID
1. 原子性(Atomicity) 一个原子事务要么完整执行,要么干脆不执行.这意味着,工作单元中的每项任务都必须正确执行.如果有任一任务执行失败,则整个工作单元或事务就会被终止.即此前对数据所作的任 ...
- https://jwt.io/一个可以解析token的神奇网站
网址:https://jwt.io/ 效果:
- appium---uiautomator定位方法
前面总结了7种定位方法,今天在介绍一种uiautomator方法,其实appium就是基于uiautomator框架实现的,让我们一起看下uiautomator有哪些定位方法可以使用 uiautoma ...