예제 #1
0
        //Метод отрисовки включенного сигнала
        public void DrawCurveSignal(SignalObj signal, Graphics g)
        {//3 пера для создания более красивой кривой сигнала
            Pen penFun1; Pen penFun2; Pen penFun3;

            penFun1 = new Pen(Color.FromArgb(100, col), 5);
            penFun2 = new Pen(Color.FromArgb(200, col), 2);
            penFun3 = new Pen(Color.FromArgb(180, Color.White), 1);

            if (signal.Garm == 1)//сигнал гармонический
            {
                g.DrawLines(penFun2, signal.listP.ToArray());
                g.DrawLines(penFun1, signal.listP.ToArray());
                g.DrawLines(penFun3, signal.listP.ToArray());
            }
            else if (signal.Garm == 0)//сигнал импульсный
            {
                for (int i = 0; i < signal.listP.Count - 1; i = i + 2)
                {
                    g.DrawLine(penFun2, signal.listP[i], signal.listP[i + 1]);
                    g.DrawLine(penFun1, signal.listP[i], signal.listP[i + 1]);
                    g.DrawLine(penFun3, signal.listP[i], signal.listP[i + 1]);
                }
            }
            penFun1.Dispose(); penFun2.Dispose(); penFun3.Dispose();
        }
예제 #2
0
 //Создание второго сигнала
 private void createSignal2_Click(object sender, EventArgs e)
 {
     signGener.Visible = true;
     signal2           = new SignalObj(display.XSize);
     signal2.Ok        = true;
     if (signal1 != null)
     {
         signal1.Ok = false;
     }
 }
예제 #3
0
 //Изменение сигнала
 public void SignalIsChanged(SignalObj s, int y)
 {
     if (s == null)
     {
         return;
     }
     s.listP.Clear();
     if (s.Garm == 1)
     {
         s.CalculateSin(y, -width, width);
     }
     else if (s.Garm == 0)
     {
         s.CalculateImp(y, -width, width);
     }
 }
예제 #4
0
        //Смещение кривой сигнала
        public void moving(SignalObj s, int dx, int dy)
        {
            if (s == null)
            {
                return;
            }
            PointF pnt;

            //сдвиг каждой точки в списке с помощью цикла
            for (int i = 0; i < s.listP.Count; i++)
            {
                pnt        = s.listP[i];
                pnt        = new PointF(s.listP[i].X + dx, s.listP[i].Y + dy);
                s.listP[i] = pnt;
            }
        }
예제 #5
0
 //открытие сигнала
 private void открытьToolStripMenuItem_Click(object sender, EventArgs e)
 {
     if (Channel1 == false && Channel2 == false)
     {
         MessageBox.Show("выберите канал для отображения сигнала");
         return;
     }
     if (Channel1 == true)
     {
         signal1 = Sm.OpenSignal();
     }
     if (Channel2 == true)
     {
         signal2 = Sm.OpenSignal();
     }
     display.Refresh();
 }
예제 #6
0
 //Cоздание нового сигнала
 public void CreateNewSignal(int y, SignalObj sg, GeneratorSignals gs)
 {
     //гармонический сигнал
     if (gs.garmon.Checked == true & sg != null)
     {
         sg.Garm = 1;
         sg.U    = gs.U;
         sg.F    = gs.F;
         sg.listP.Clear();
         sg.CalculateSin(y, -width, width);
     }
     //импульсный сигнал
     if (gs.impul.Checked == true)
     {
         sg.Garm = 0;
         sg.U    = gs.U;
         sg.F    = gs.F;
         sg.ti   = gs.Dp;
         sg.CalculateImp(y, -width, width);
     }
 }
예제 #7
0
        //Метод сохранения сигнала
        public void SaveSignal(SignalObj sn)
        {
            SaveFileDialog sfd = new SaveFileDialog();

            sfd.Filter = "dat |*.dat";
            if (sfd.ShowDialog() != DialogResult.OK)
            {
                return;
            }
            FileStream fs = new FileStream(sfd.FileName,
                                           FileMode.Create);

            if (fs == null)
            {
                return;
            }
            BinaryFormatter BFormater = new BinaryFormatter();

            BFormater.Serialize(fs, sn);
            fs.Close();
        }
예제 #8
0
        //Метод отрисовки включенного сигнала
        public void DrawCurveSignal(SignalObj signal, Graphics g)
        {
            penFun1 = new Pen(Color.FromArgb(100, col), 5);
            penFun2 = new Pen(Color.FromArgb(200, col), 2);

            if (signal.Garm == 1)//сигнал гармонический
            {
                g.DrawLines(penFun2, signal.listP.ToArray());
                g.DrawLines(penFun1, signal.listP.ToArray());
                g.DrawLines(penFun3, signal.listP.ToArray());
            }
            else if (signal.Garm == 0)//сигнал импульсный
            {
                for (int i = 0; i < signal.listP.Count - 1; i = i + 2)
                {
                    g.DrawLine(penFun2, signal.listP[i], signal.listP[i + 1]);
                    g.DrawLine(penFun1, signal.listP[i], signal.listP[i + 1]);
                    g.DrawLine(penFun3, signal.listP[i], signal.listP[i + 1]);
                }
            }
        }
예제 #9
0
        //Метод открытия сигнала
        public SignalObj OpenSignal()
        {
            SignalObj      sn = new SignalObj(dis.XSize);
            string         str;
            OpenFileDialog ofd = new OpenFileDialog();

            ofd.Filter = "dat |*.dat";
            if (ofd.ShowDialog() != DialogResult.OK)
            {
                return(null);
            }
            ofd.FilterIndex = 1;
            str             = ofd.FileName;
            FileStream      bfs = File.OpenRead(str);
            BinaryFormatter bf  = new BinaryFormatter();
            object          оb;

            try
            {
                оb = bf.Deserialize(bfs);
            }
            catch
            {
                MessageBox.Show("Данный файл не соответствует структуре сигнала");
                return(null);
            }
            bfs.Close();
            //Убеждаемся в том, что объект нужного нам типа
            sn = оb as SignalObj;
            if (sn != null)
            {
                return(sn);
            }
            else
            {
                MessageBox.Show("Данный файл не соответствует структуре сигнала");
                return(null);
            }
        }
예제 #10
0
        //Определение попадания курсора в кривую сигнала
        public bool IsIntoSignal(SignalObj s, int x, int y)
        {
            Point p     = new Point(x, y);
            bool  ok    = false;
            int   index = 0;

            for (int i = 0; i < s.listP.Count; i++)
            {
                if (p.X == s.listP[i].X) //определение точки Х, при которой
                {                        //координата Х курсора мыши будет равна точке Х в списке
                    index = i;           //чтобы затем не перебирать точки в списке
                    break;               //от нулевого элемента
                }
            }
            int j = 0;
            int k = 0;

            if (s.Garm == 1)//сигнал гармонический
            {
                for (int i = index; i < s.listP.Count - 1; i++)
                {
                    if (ok)
                    {
                        break;
                    }
                    for (j = p.X; j < p.X + 7; j++)
                    {
                        if (ok)
                        {
                            break;    //если ок уже тру, то останавливаем цикл
                        }
                        for (k = p.Y; k < p.Y + 7; k++)
                        {
                            if (j == s.listP[i].X && k == (int)s.listP[i].Y)
                            {//если нашлась нужная точка (попали)
                                ok = true;
                                break;
                            }
                        }
                    }
                    if (ok != true)
                    {
                        for (j = p.X; j > p.X - 7; j--)
                        {
                            if (ok)
                            {
                                break;
                            }
                            {
                                for (k = p.Y; k > p.Y - 7; k--)
                                {
                                    if (j == s.listP[i].X && k == (int)s.listP[i].Y)
                                    {
                                        ok = true;
                                        break;
                                    }
                                }
                            }
                        }
                    }
                }
            }
            else if (s.Garm == 0)//сигнал импульсный
            {
                for (int i = index; i < s.listP.Count - 1; i = i + 2)
                {
                    for (j = p.Y; j < p.Y + 7; j++)
                    {
                        if (j == s.listP[i].Y)
                        {//если нашлась нужная точка (попали)
                            ok = true;
                            break;
                        }
                    }
                    if (ok != true)
                    {
                        for (j = p.Y; j < p.Y - 7; j--)
                        {
                            if (j == s.listP[i].Y)
                            {
                                ok = true;
                                break;
                            }
                        }
                    }
                }
            }

            if (ok == true)//возвращаем конечное значение
            {
                return(true);
            }
            else
            {
                return(false);
            }
        }