Ejemplo n.º 1
0
        /// <summary>
        /// Работаем со скоростью
        /// </summary>
        /// <param name="list"></param>
        /// <returns></returns>
        private void CalcKalmanV(List <PointCoords> list, string strName, bool iIsPredict, bool bNoA)
        {
            var listKalman = new PointsCoordSet(strName);

            if (list.Count <= 0)
            {
                return;
            }
            var KallFilX = new Kalc3Dim("X", true);
            var KallFilY = new Kalc3Dim("Y", false);
            var Num      = list[0].NumFrame - 1;

            for (var jc = 0; jc < list.Count; jc++)
            {
                var pt  = new Point(list[jc].X, list[jc].Y);
                var ptC = list[jc] + pt;
                ptC.col = Color.Fuchsia;
                if (list[jc].X == -1)
                {
                    ptC.col = Color.Yellow;
                }
                var x = KallFilX.SetData(list[jc].X, list[jc].NumFrame, iIsPredict, bNoA);
                var y = KallFilY.SetData(list[jc].Y, list[jc].NumFrame, iIsPredict, bNoA);
                ptC.X = (int)x;
                ptC.Y = (int)y;
                //PointCoords ptC = KallFil.CalcEstimationPoint(pt, list[jc].NumFrame) + list[jc];

                listKalman.Add(ptC);
            }
            PointsCoordSet.AddList(listKalman);
        }
Ejemplo n.º 2
0
 /// <summary>
 ///
 /// </summary>
 /// <param name="sender"></param>
 /// <param name="e"></param>
 private void отметитьОбъектыToolStripMenuItem_Click(object sender, EventArgs e)
 {
     if (sPictureDir == "")
     {
         MessageBox.Show("Не задана директория");
         return;
     }
     if (strLog == null)
     {
         MessageBox.Show("Не задан файл координат");
         return;
     }
     listMarkedPC = new PointsCoordSet("Marked");
     PointsCoordSet.AddList(listMarkedPC);
     //
     //FillCoordData();
     отметитьОбъектыToolStripMenuItem.Enabled = false;
     bMark = true;
     buttonright.Enabled = false;
     buttonLeft.Enabled  = false;
 }
Ejemplo n.º 3
0
        /// <summary>
        ///
        /// </summary>
        /// <returns></returns>
        //private bool FillCoordData(StreamReader sr, List<PointCoords> list,bool bIsNeed,Color col)
        private bool FillCoordData(StreamReader sr, PointsCoordSet list, bool bIsNeed, Color col)
        {
            if (sr == null)
            {
                if (bIsNeed)
                {
                    MessageBox.Show("Не задан файл координат");
                }
                return(false);
            }
            //list = new List<PointCoords>();
            string strTemp;
            var    iNum = -1;

            while (true)
            {
                strTemp = sr.ReadLine();
                if (strTemp == null)
                {
                    break;
                }

                var pC = new PointCoords();
                if (pC.SetDataFromFile(strTemp, col) == false)
                {
                    continue;
                }
                if (iNum == -1)
                {
                    iNum = pC.NumFrame;
                }
                else
                {
                    iNum++;
                    if (pC.NumFrame > iNum)
                    {
                        var iNumDel = pC.NumFrame;
                        while (iNumDel != iNum)
                        {
                            var pC1 = new PointCoords();
                            pC1.NumFrame = iNum;
                            pC1.col      = pC.col;
                            pC1.Width    = pC.Width;
                            list.Add(pC1);
                            iNum++;
                        }
                    }
                }
                list.Add(pC);
            }
            if (NCurrentFile == -1)
            {
                NCurrentFile = NFirstFile = list[0].NumFrame;
                NLastFile    = list[list.Count - 1].NumFrame;
            }
            var iReminder = NLastFile - NFirstFile + 1 - list.Count;

            iNum++;
            for (var jc = 0; jc < iReminder; jc++)
            {
                var pC1 = new PointCoords();
                pC1.NumFrame = iNum;
                pC1.col      = Color.AntiqueWhite;
                pC1.Width    = 40;
                list.Add(pC1);
                iNum++;
            }
            PointsCoordSet.AddList(list);
            return(true);
        }