C#绘制阻抗圆图初步

阻抗圆图,或者叫史密斯图,是无线电设计方面用的;

基本的阻抗圆图如下,

下面尝试用C#能不能画一下;

先在网上找一个画坐标的C#类,它的效果如下;

 

自己再增加一个函数,可以绘制中心在画布中心的坐标系;

 

看一下基本的阻抗圆图,它有4个圆;先把4个圆画一下如下,

 

那几条曲线不知道怎么画,不知道是什么曲线,用什么函数描述; 有时间继续;

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Drawing;
using System.Drawing.Drawing2D;namespace commengineer
{public static class XYlinesFactory{#region   画出X轴与Y轴/// <summary>  /// 在任意的panel里画一个坐标,坐标所在的四边形距离panel边50像素  /// </summary>  /// <param name="pan"></param>  public static void DrawXY(Panel pan){Graphics g = pan.CreateGraphics();//整体内缩move像素  float move = 50f;float newX = pan.Width - move;float newY = pan.Height - move;//绘制X轴,  PointF px1 = new PointF(move, newY);PointF px2 = new PointF(newX, newY);g.DrawLine(new Pen(Brushes.Black, 2), px1, px2);//绘制Y轴  PointF py1 = new PointF(move, move);PointF py2 = new PointF(move, newY);g.DrawLine(new Pen(Brushes.Black, 2), py1, py2);}#endregionpublic static void DrawCXY(Panel pan){Graphics g = pan.CreateGraphics();//整体内缩move像素  float move = 50f;float newX = pan.Width - move;float newY = pan.Height - move;float x1 = move / 2;float x2 = move / 2 + newX;float y1 = newY / 2 + move/2;PointF p1 = new PointF(x1, y1);PointF p2 = new PointF(x2, y1);PointF p3 = new PointF(move/2 + newX/2, move/2);PointF p4 = new PointF(move / 2 + newX / 2, pan.Height - move/2);g.DrawLine(new Pen(Brushes.Black, 1), p1, p2);g.DrawLine(new Pen(Brushes.Black, 1), p3, p4);}public static void DrawSmithCircle(Panel pan){Graphics g = pan.CreateGraphics();float bound = 50f;float centerX = pan.Width / 2;float centery = pan.Height / 2;float scr1 = ((pan.Width - bound) /2) * 0.8f;float scr2 = (scr1 + scr1 / 2) / 2;float scr3 = scr1 / 2;float scr4 = scr3 / 2;//float r1 = ((pan.Width - 50f) / 2) * 0.8f;//GraphicsPath circlePath = new GraphicsPath();//circlePath.AddEllipse(pan.Width/2, pan.Height/2, r1, r1);// 设置画笔和填充色//Brush brush = Brushes.Blue;// 绘制圆g.DrawEllipse(new Pen(Brushes.Black, 1), centerX - scr1, centery - scr1, scr1*2, scr1*2);g.DrawEllipse(new Pen(Brushes.Black, 1), centerX - scr1/2, centery - scr2, scr2 * 2, scr2 * 2);g.DrawEllipse(new Pen(Brushes.Black, 1), centerX, centery - scr3, scr3 * 2, scr3 * 2);g.DrawEllipse(new Pen(Brushes.Black, 1), centerX+scr3, centery - scr4, scr4 * 2, scr4 * 2);//g.FillPath(brush, circlePath);}/// <summary>  /// 画出Y轴上的分值线,从零开始  /// </summary>  /// <param name="pan"></param>  /// <param name="maxY"></param>  /// <param name="len"></param>  #region   画出Y轴上的分值线,从零开始public static void DrawYLine(Panel pan, float maxY, int len){float move = 50f;float LenX = pan.Width - 2 * move;float LenY = pan.Height - 2 * move;Graphics g = pan.CreateGraphics();for (int i = 0; i <= len; i++)    //len等份Y轴  {PointF px1 = new PointF(move, LenY * i / len + move);PointF px2 = new PointF(move + 4, LenY * i / len + move);string sx = (maxY - maxY * i / len).ToString();g.DrawLine(new Pen(Brushes.Black, 2), px1, px2);StringFormat drawFormat = new StringFormat();drawFormat.Alignment = StringAlignment.Far;drawFormat.LineAlignment = StringAlignment.Center;g.DrawString(sx, new Font("宋体", 8f), Brushes.Black, new PointF(move / 1.2f, LenY * i / len + move * 1.1f), drawFormat);}Pen pen = new Pen(Color.Black, 1);g.DrawString("Y轴", new Font("宋体 ", 10f), Brushes.Black, new PointF(move / 3, move / 2f));}#endregion/// <summary>  /// 画出Y轴上的分值线,从任意值开始  /// </summary>  /// <param name="pan"></param>  /// <param name="minY"></param>  /// <param name="maxY"></param>  /// <param name="len"></param>  #region   画出Y轴上的分值线,从任意值开始public static void DrawYLine(Panel pan, float minY, float maxY, int len){float move = 50f;float LenX = pan.Width - 2 * move;float LenY = pan.Height - 2 * move;Graphics g = pan.CreateGraphics();for (int i = 0; i <= len; i++)    //len等份Y轴  {PointF px1 = new PointF(move, LenY * i / len + move);PointF px2 = new PointF(move + 4, LenY * i / len + move);string sx = (maxY - (maxY - minY) * i / len).ToString();g.DrawLine(new Pen(Brushes.Black, 2), px1, px2);StringFormat drawFormat = new StringFormat();drawFormat.Alignment = StringAlignment.Far;drawFormat.LineAlignment = StringAlignment.Center;g.DrawString(sx, new Font("宋体", 8f), Brushes.Black, new PointF(move / 1.2f, LenY * i / len + move * 1.1f), drawFormat);}Pen pen = new Pen(Color.Black, 1);g.DrawString("Y轴", new Font("宋体 ", 10f), Brushes.Black, new PointF(move / 3, move / 2f));}#endregion/// <summary>  /// 画出X轴上的分值线,从零开始  /// </summary>  /// <param name="pan"></param>  /// <param name="maxX"></param>  /// <param name="len"></param>  #region   画出X轴上的分值线,从零开始public static void DrawXLine(Panel pan, float maxX, int len){float move = 50f;float LenX = pan.Width - 2 * move;float LenY = pan.Height - 2 * move;Graphics g = pan.CreateGraphics();for (int i = 1; i <= len; i++){PointF py1 = new PointF(LenX * i / len + move, pan.Height - move - 4);PointF py2 = new PointF(LenX * i / len + move, pan.Height - move);string sy = (maxX * i / len).ToString();g.DrawLine(new Pen(Brushes.Black, 2), py1, py2);g.DrawString(sy, new Font("宋体", 8f), Brushes.Black, new PointF(LenX * i / len + move, pan.Height - move / 1.1f));}Pen pen = new Pen(Color.Black, 1);g.DrawString("X轴", new Font("宋体 ", 10f), Brushes.Black, new PointF(pan.Width - move / 1.5f, pan.Height - move / 1.5f));}#endregion#region   画出X轴上的分值线,从任意值开始/// <summary>  /// 画出X轴上的分值线,从任意值开始  /// </summary>  /// <param name="pan"></param>  /// <param name="minX"></param>  /// <param name="maxX"></param>  /// <param name="len"></param>  public static void DrawXLine(Panel pan, float minX, float maxX, int len){float move = 50f;float LenX = pan.Width - 2 * move;float LenY = pan.Height - 2 * move;Graphics g = pan.CreateGraphics();for (int i = 0; i <= len; i++){PointF py1 = new PointF(LenX * i / len + move, pan.Height - move - 4);PointF py2 = new PointF(LenX * i / len + move, pan.Height - move);string sy = ((maxX - minX) * i / len + minX).ToString();g.DrawLine(new Pen(Brushes.Black, 2), py1, py2);g.DrawString(sy, new Font("宋体", 8f), Brushes.Black, new PointF(LenX * i / len + move, pan.Height - move / 1.1f));}Pen pen = new Pen(Color.Black, 1);g.DrawString("X轴", new Font("宋体 ", 10f), Brushes.Black, new PointF(pan.Width - move / 1.5f, pan.Height - move / 1.5f));}#endregion  }
}

调用代码;

        private void toolStripMenuItem2_Click(object sender, EventArgs e){//XYlinesFactory.DrawXY(panel1);//XYlinesFactory.DrawXLine(panel1, 100.00f, 12);//XYlinesFactory.DrawYLine(panel1, 100.00f, 12);XYlinesFactory.DrawCXY(panel1);XYlinesFactory.DrawSmithCircle(panel1);}private void Form8_Load(object sender, EventArgs e){panel1.Width = 600;panel1.Height = 600;}

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/45234.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

地址翻译过程(TLB-->页表-->Cache-->主存-->外存)

目录 1.地址结构 2.查找快表或页表&#xff1a;从虚拟地址--->物理地址 3.通过物理地址访问数据 设某系统满足以下条件&#xff1a; •有一个TLB与一个data Cache •存储器以字节为编址单位 •虚拟地址 14位 •物理地址 12位 •页面大小为 64B •TLB 为四路组相联&#x…

消防灭火设备软体水枪的使用方法

软体水枪是一款专为消防、应急救援等领域设计的灭火工具。其内胆采用大容量设计&#xff0c;能够储存足够的灭火剂&#xff0c;满足长时间、大范围的灭火需求。软体水枪是一种高效、便捷的灭火工具。它利用压力和流体力学原理&#xff0c;通过扣动扳机将储水箱中的水以高速喷射…

《金山 WPS AI 2.0:重塑办公未来的智能引擎》

AITOP100平台获悉&#xff0c;在 2024 世界人工智能大会这一科技盛宴上&#xff0c;金山办公以其前瞻性的视野和创新的技术&#xff0c;正式发布了 WPS AI 2.0&#xff0c;犹如一颗璀璨的星辰&#xff0c;照亮了智能办公的新征程&#xff0c;同时首次公开的金山政务办公模型 1.…

PyTorch | 加速模型训练的妙招

引言 提升机器学习模型的训练速度是每位机器学习工程师的共同追求。训练速度的提升意味着实验周期的缩短&#xff0c;进而加速产品的迭代过程。同时&#xff0c;这也表示在进行单一模型训练时&#xff0c;所需的资源将会减少。简而言之&#xff0c;我们追求的是效率。 熟悉 PyT…

SpringSecurity框架【认证】

目录 一. 快速入门 二. 认证 2.1 登陆校验流程 2.2 原理初探 2.3 解决问题 2.3.1 思路分析 2.3.2 准备工作 2.3.3 实现 2.3.3.1 数据库校验用户 2.3.3.2 密码加密存储 2.3.3.3 登录接口 2.3.3.4 认证过滤器 2.3.3.5 退出登录 Spring Security是Spring家族中的一个…

机器学习(V)--无监督学习(三)EM算法

EM算法 极大似然估计 极大似然估计&#xff1a;(maximum likelihood estimate, MLE) 是一种常用的模型参数估计方法。它假设观测样本出现的概率最大&#xff0c;也即样本联合概率&#xff08;也称似然函数&#xff09;取得最大值。 为求解方便&#xff0c;对样本联合概率取对…

华为HCIP Datacom H12-821 卷36

1.单选题 在PIM- SM中&#xff0c;以下关于RP 的描述&#xff0c;错误的是哪一选项? A、在PIM-SM中&#xff0c;组播数据流量不一定必须经过RP的转发。 B、对于一个组播组来说&#xff0c;可以同时有多个RP地址&#xff0c;提升网络可靠性。 C、组播网络中&#xff0c;可以…

【BUG】已解决:JsonMappingException

已解决&#xff1a;JsonMappingException 欢迎来到英杰社区https://bbs.csdn.net/topics/617804998 概述&#xff1a; 没有getter方法的实体的序列化&#xff0c;并解决Jackson引发的JsonMappingException异常。 默认情况下&#xff0c;Jackson 2只会处理公有字段或具有公有get…

Renesas R7FA8D1BH (Cortex®-M85) 控制DS18B20

目录 概述 1 软硬件 1.1 软硬件环境信息 1.2 开发板信息 1.3 调试器信息 2 FSP和KEIL配置 2.1 硬件接口电路 2.2 FSB配置DS18B20的IO 2.3 生成Keil工程文件 3 DS18B20驱动代码 3.1 DS18B20介绍 3.2 DS18B20驱动实现 3.2.1 IO状态定义 3.2.2 读IO状态函数 3.2.3…

OpenCV:python图像旋转,cv2.getRotationMatrix2D 和 cv2.warpAffine 函数

前言 仅供个人学习用&#xff0c;如果对各位朋友有参考价值&#xff0c;给个赞或者收藏吧 ^_^ 一. cv2.getRotationMatrix2D(center, angle, scale) 1.1 参数说明 parameters center&#xff1a;旋转中心坐标&#xff0c;是一个元组参数(col, row) angle&#xff1a;旋转角度…

Go-知识测试-模糊测试

Go-知识测试-模糊测试 1. 定义2. 例子3. 数据结构4. tesing.F.Add5. 模糊测试的执行6. testing.InternalFuzzTarget7. testing.runFuzzing8. testing.fRunner9. FuzzXyz10. RunFuzzWorker11. CoordinateFuzzing12. 总结 建议先看&#xff1a;https://blog.csdn.net/a1879272183…

一文入门【NestJs】Providers

Nest学习系列 ✈️一文入门【NestJS】 ✈️一文入门【NestJs】Controllers 控制器 &#x1f6a9; 前言 在NestJS的世界里&#xff0c;理解“Providers”是构建健壮、可维护的后端服务的关键。NestJS&#xff0c;作为Node.js的一个现代框架&#xff0c;采用了Angular的一些核…

Redis的安装配置及IDEA中使用

目录 一、安装redis&#xff0c;配置redis.conf 1.安装gcc 2.将redis的压缩包放到指定位置解压 [如下面放在 /opt 目录下] 3.编译安装 4.配置redis.conf文件 5.开机自启 二、解决虚拟机本地可以连接redis但是主机不能连接redis 1.虚拟机网络适配器网络连接设置为桥接模式…

VSCode上通过C++实现单例模式

单例模式实际上就是为了确保一个类最多只有一个实例&#xff0c;并且在程序的任何地方都可以访问这个实例&#xff0c;也就是提供一个全局访问点&#xff0c;单例对象不需要手动释放&#xff0c;交给系统来释放就可以了&#xff0c;单例模式的设计初衷就是为了在整个应用程序的…

vue 下拉菜单树形结构——vue-treeselect的组件使用

参考&#xff1a; https://www.cnblogs.com/syjtiramisu/p/17672866.htmlhttps://www.cnblogs.com/syjtiramisu/p/17672866.html vue-treeselect的使用 - 简书下载依赖 使用https://www.jianshu.com/p/459550e1477d 实际项目使用&#xff1a;

uni-app iOS上架相关App store App store connect 云打包有次数限制

相册权限 uni-app云打包免费有次数 切换一个账号继续

华为手机联系人不见了怎么恢复?3个解决方案

华为手机联系人列表就像是我们精心编织的社交网络之网。然而&#xff0c;有时&#xff0c;这张网可能会因为各种原因而意外破损&#xff0c;联系人信息消失得无影无踪&#xff0c;让我们陷入“人脉孤岛”的困境。华为手机联系人不见了怎么恢复&#xff1f;别担心&#xff0c;我…

构建高质量数据集与智能数据工程平台:播客AI Odyssey深度对话实录

对话整数智能联创和前IDEA研究员&#xff1a;构建高质量数据集与智能数据工程平台 - AI Odyssey | 小宇宙 - 听播客&#xff0c;上小宇宙 人工智能技术的日益深远发展&#xff0c;对人工智能的性能提升与技术迭代提出了新的要求。在大模型训练中&#xff0c;已有的研究和实践表…

【操作系统】进程管理——用信号量机制解决问题,以生产者-消费者问题为例(个人笔记)

学习日期&#xff1a;2024.7.10 内容摘要&#xff1a;利用信号量机制解决几个经典问题模型 目录 引言 问题模型 生产者-消费者问题&#xff08;经典&#xff09; 多生产者-多消费者问题 吸烟者问题 读者写者问题&#xff08;难点&#xff09; 哲学家进餐问题&#xff0…

解决POST请求中文乱码问题

解决POST请求中文乱码问题 1、乱码原因2、解决方法3、具体步骤 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&#x1f496; 在Web开发中&#xff0c;处理POST请求时经常遇到中文乱码问题&#xff0c;这主要是由于服务器在接收到POST请求的数据后&#x…