正弦波

Posted rb-huang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了正弦波相关的知识,希望对你有一定的参考价值。

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Drawing.Drawing2D;
namespace CoordinateSystem
{
    public partial class Form1 : Form
    {
        int orgX = 20;
        int orgY = 20;//原点距离边框左,下距离
        int move = 20;//格子间隔
        int timerI = 0;
       
        public Form1()
        {
            InitializeComponent();
            timer1.Interval = 1000;
            timer1.Enabled = true;
        }
       
        private void panel1_Paint(object sender, PaintEventArgs e)
        {
           
          
            Draw draw = new Draw();
            draw.DrawX(move,panel1,orgX,orgY);
            draw.DrawY(move, panel1, orgX, orgY);
           
        }
     
        private void button1_Click(object sender, EventArgs e)
        {
            panel1.Refresh();
            Graphics g = panel1.CreateGraphics();
          
            Pen pen = new Pen(Color.Red, 1);
            double x1 = panel1.Width/2;
            double y1 = 0;
          
            for (double x = 1; x < panel1.Width; x++)//这一块就是画正弦波的位置  panel1.width/2是偏移波到坐标系0点起始的作用。
            {
                //SIN最大值为1,而我图上用了100像素,所以有
                //100/1=100 故而y要乘100;
                // x/180*Math.PI 这个表达式把角度换成弧度值
                double y = Math.Sin(x / 180 * Math.PI) * 60;
                //SIN值一个循环为360度,而我图上用了200像素表示,所以有:
                //360/200=1.8 故而x值要除1.8
                //Matrix myMatrix = new Matrix(1, 0, 0, -1, 0, 0);
                //g.Transform = myMatrix;
                //g.TranslateTransform(0, (float)panel1.Height / 2);//画图前发这个,移动到X,Y位置
                g.DrawLine(pen, (float)x1, (float)y1 + 60, (float)(x / 1.8) + panel1.Width / 2, (float)y + 60);
                x1 = x / 1.8 + panel1.Width / 2;
                y1 = y;
            }
            //pictureBoxFrequencyDomain.Image = bitmap;
            // Graphics g = panel1.CreateGraphics();
            // g.DrawEllipse(new Pen(Color.Red, 2), panel1.Width / 2 - 50, panel1.Height / 2 - 50, 100, 100);//红色不填充圆
            // g.FillEllipse(new SolidBrush(Color.Red), panel1.Width / 2 - 50, panel1.Height / 2 - 50, 100, 100);//红色填充圆
        }
    }
    public class Draw
    {
        //X轴方法
        public void DrawX(int move,Panel panel,int orgX,int orgY)//画X轴上分格
        {
           
          
            int a = (panel.Width/2) / move;//X轴有多少格
            Graphics g = panel.CreateGraphics();
           
            g.DrawLine(new Pen(Color.Black, 3), new Point(panel.Width/2, panel.Height),//画X轴长线
                                                new Point(panel.Width/2, 0));

            for (int i = 0; i < a; i++)
            {
                g.DrawLine(new Pen(Color.Black, 3), new Point(panel.Width/2+ move * i, panel.Height/2),
                           new Point(panel.Width / 2 + move * i, panel.Height / 2 - 4));//划分+格子
                g.DrawLine(new Pen(Color.Black, 3),new Point(panel.Width / 2 - move * i, panel.Height / 2),
                            new Point(panel.Width / 2 - move * i, panel.Height / 2 - 4));//划分-格子
                g.DrawString(i.ToString(), new Font("宋体", 8f), Brushes.Black, panel.Width / 2 + move * i,
                                                                      panel.Height / 2 + 4 );//写X轴+的数字
                if (i!=0)
                {
                    g.DrawString("-" + i.ToString(), new Font("宋体", 8f), Brushes.Black, panel.Width / 2 - move * i,
                                                                                          panel.Height / 2 + 4);//写X轴-的数字
                }
               
            }
            g.DrawString("X轴", new Font("宋体", 10f), Brushes.Black, panel.Width-30, panel.Height/2+20);
        }
        public void DrawY(int move,Panel pan,int orgX,int orgY)
        {
            Graphics g = pan.CreateGraphics();
            g.DrawLine(new Pen(Color.Black, 3), new Point(0, pan.Height/2),
                                                new Point(pan.Width, pan.Height / 2));//画Y轴长线
            int a = (pan.Height/2) / move;
            for (int i = 0; i < a; i++)
            {
                g.DrawLine(new Pen(Color.Black, 3), new Point(pan.Width/2, pan.Height/2 - move * i),
                           new Point(pan.Width / 2 + 4, pan.Height / 2 - move * i));
                g.DrawLine(new Pen(Color.Black, 3), new Point(pan.Width / 2, pan.Height / 2 + move * i),
                           new Point(pan.Width / 2 + 4, pan.Height / 2 + move * i));
                if (i!=0)
                {
                    g.DrawString(i.ToString(), new Font("宋体", 8f), Brushes.Black, pan.Width / 2 - 10,
                    pan.Height / 2 

 

- move * i);
                    g.DrawString("-"+i.ToString(), new Font("宋体", 8f), Brushes.Black, pan.Width / 2 - 15,
                    pan.Height / 2 + move * i);
                }
               
            }
            g.DrawString("Y轴", new Font("宋体", 10f),Brushes.Black, orgX, orgY - 20);
           
        }
    }
}
 
以下是运行后的界面
技术图片

 

以上是关于正弦波的主要内容,如果未能解决你的问题,请参考以下文章

用FPGA产生正弦波

正弦信号怎么变成方波信号,需要怎么处理?

利用运放怎样实现由方波变成正弦波

正弦波转换为方波

如何讲正弦波转化为方波?频率不变。

方波,正弦波,三角波信号是如何产生的