Exemple #1
0
        private void DrawDiagram()
        {
            verticalMargin = 80;
            int treeHeight = ViewModel.TreeHight;
            int maxNodes   = (int)Math.Pow(2, (double)treeHeight);

            diagramWidth = (nodeWidth + margin) * maxNodes;
            int diagramHeight = verticalMargin * treeHeight;

            //zwiekszenie szerokosci kanwy o 10%
            diagramWidth   *= 1.1;
            treeView.Width  = diagramWidth < mainWindow.ActualWidth ? mainWindow.ActualWidth : diagramWidth;
            treeView.Height = diagramHeight < mainWindow.Height ? mainWindow.Height : diagramHeight;
            nodeWidth       = 50;
            nodeHeight      = 50;
            margin          = 0;

            Node       rootNode = ViewModel.Nodes.FirstOrDefault();
            double     x        = treeView.Width / 2;
            double     y        = 10;
            NodeCircle root     = new NodeCircle(rootNode.Frequency);

            treeView.Children.Clear();
            treeView.Children.Add(root);
            root.SetValue(Canvas.LeftProperty, x);
            root.SetValue(Canvas.TopProperty, y);
            double distance = diagramWidth / 2;

            drawTree(rootNode, x, y, distance, x, y, 1);
        }
Exemple #2
0
        private void drawTree(Node node, double x, double y, double distance, double x2, double y2, int sign)
        {
            distance = distance / 2;
            int labelSign = sign;

            if (node.Right != null)
            {
                drawTree(node.Right, x + distance + margin, y + verticalMargin, distance, x, y, 1);
            }

            if (node.Left != null)
            {
                drawTree(node.Left, x - distance - margin, y + verticalMargin, distance, x, y, 0);
            }


            if (node.IsLeaf)
            {
                LeafNode leaf = new LeafNode(node.Frequency, node.Symbol);
                treeView.Children.Add(leaf);
                leaf.SetValue(Canvas.LeftProperty, x);
                leaf.SetValue(Canvas.TopProperty, y);
                leaf.SetValue(Canvas.ZIndexProperty, 2);
            }
            else
            {
                NodeCircle nodeCircle = new NodeCircle(node.Frequency);
                treeView.Children.Add(nodeCircle);
                nodeCircle.SetValue(Canvas.LeftProperty, x);
                nodeCircle.SetValue(Canvas.TopProperty, y);
                nodeCircle.SetValue(Canvas.ZIndexProperty, 2);
            }
            if (x != x2)
            {
                Line line = new Line()
                {
                    X1 = x + nodeWidth / 2, Y1 = y + nodeHeight / 2, X2 = x2 + nodeWidth / 2, Y2 = y2 + nodeHeight / 2, StrokeThickness = 2, Stroke = new SolidColorBrush(Colors.Black)
                };
                Label label = new Label()
                {
                    Content = labelSign.ToString(), FontSize = 14
                };
                treeView.Children.Add(line);
                treeView.Children.Add(label);
                if (sign == 1)
                {
                    label.SetValue(Canvas.LeftProperty, x2 + (x - x2) * 0.5 + nodeWidth / 2);
                }
                else
                {
                    label.SetValue(Canvas.LeftProperty, x2 - (x2 - x) * 0.5);
                }

                label.SetValue(Canvas.TopProperty, y - verticalMargin * 0.5);
            }
        }