winform中使用SVG矢量圖,動態建立加載簡單矢量圖形

       SVG文件加載

      在winform中使用webbrowers控件加載外部html靜態頁面,在頁面中使用SVG圖形,在使用script可作到動態更新svg圖形。在實際使用中發如今html中直接使用svg後,在webbrowers中沒法顯示svg圖形,在web中使用svg可參考如下連接,示例中的方式都沒法知足winform中使用。最後嘗試直接在webbrowers中加載svg文件,發現可正常使用,後面只須要解決動態建立和刷新問題便可。
javascript

 1                 string pathSvgScript = AppDomain.CurrentDomain.BaseDirectory + @"images\deviceView\svgScript.svg";
 2                 string pathSvgLine = AppDomain.CurrentDomain.BaseDirectory + @"images\deviceView\svgLine.svg";
 3 
 4 
 5                 string a = "<?xml version=\"" + "1.0" + "\"" + " encoding=\"" + "utf-8\"?>" + "\r\n";//gbk
 6 
 7                 XDocument docSvgLine = XDocument.Load(pathSvgLine);
 8                 docSvgLine = SetLine(docSvgLine);
 9 
10 
11                 XElement eleSvgLine = XElement.Parse(docSvgLine.ToString());
12                 XDocument docSvgScript = XDocument.Load(pathSvgScript);
13                 docSvgScript.Root.Add(eleSvgLine);
14 
15                 string asa = a + docSvgScript.ToString();

先將script和純svg圖形文件分開,使用setline方法動態生成svg圖形,而後將svg圖形插入到完整文件中,便可在界面正常顯示。html

 

 

xml文件操做

插入節點(可實現SVG動態建立)

        一、獲取文件 XDocument docSvgLine = XDocument.Load(pathSvgLine);java

   二、插入節點web

    若xml中上級存在命令空間,則插入下級節點時會自動添加  xmlns="" 屬性,添加後致使新插入的節點沒法正常顯示app

    須要在新建此節點時加入命名空間svg

    聲明命名空間 XNamespace aw = "http://www.w3.org/2000/svg";(根據實際狀況聲明須要的命名空間)
測試

    

1 XElement tdcSlave = new XElement(aw + "text");
2 tdcSlave.Add(new XAttribute("x", x - 100));
3 tdcSlave.Add(new XAttribute("y", yTdc));
4 tdcSlave.Add(new XAttribute("style", "fill:rgb(255,255,255); text-anchor:middle;font-weight:normal"));
5 tdcSlave.Add(new XAttribute("font-family", "SimSun"));
6 tdcSlave.Add(new XAttribute("text-anchor", "middle"));
7 tdcSlave.Add(new XAttribute("font-size", "22"));
8 tdcSlave.Add(new XElement(aw + "tspan", "測試"));
9 docSvgLine.Root.Add(tdcSlave);

 

以上代碼展現 新建一個節點,此節點加入了上級命名空間、節點中加入必要的屬性和元素,最後將節點插入到xml文件中。spa

獲取節點(可實現svg圖形實時刷新)

若節點有id屬性,可根據節點id獲取 ,(picLine爲webbrowers控件).net

                foreach (HtmlElement he in picLine.Document.All)
                {
                    if (he.GetAttribute("id") != null)
                    {
                        string id = he.GetAttribute("id");
                        if (nameId.ContainsKey(id))
                        {
                            he.InnerText = nameId[id];
                        }

                        if (id.ToLower().Contains("status"))
                        {
                            if (nameId[id] == "1")
                            {
                                he.SetAttribute("style", "fill:rgb(0,255,0);stroke-width:1;stroke:rgb(0,0,0)");
                                he.Style = "fill:rgb(0,255,0);stroke-width:1;stroke:rgb(0,0,0";
                            }
                            else if (nameId[id] == "4")
                            {
                                he.SetAttribute("style", "fill:rgb(255,0,0);stroke-width:1;stroke:rgb(0,0,0)");
                                he.Style = "fill:rgb(255,0,0);stroke-width:1;stroke:rgb(0,0,0";
                            }
                            else
                            {
                                he.SetAttribute("style", "fill:rgb(255,255,255);stroke-width:1;stroke:rgb(0,0,0)");
                                he.Style = "fill:rgb(255,255,255);stroke-width:1;stroke:rgb(0,0,0";
                            }
                        }
                    }
                }

 

 

 

 svgLine.svg文件code

<?xml version="1.0" encoding="gbk"?>

 <g id="testdrag" xmlns="http://www.w3.org/2000/svg">  

   
 </g>

svgScript.svg文件

<?xml version="1.0" encoding="gbk"?>

 <svg onmousedown="Grab(evt)" xmlns:cge="http://www.cim.com" width="1366" onmousemove="Drag(evt)" xmlns:xlink="http://www.w3.org/1999/xlink" onload="Init(evt)" xmlns="http://www.w3.org/2000/svg" height="850px" version="1.1" onmouseup="Drop(evt)" >
 <rect width="110%" x="-10%" pointer-events="all" y="-10%" fill="none" height="110%" id="BackDrop" />
 <g id="0" >
  <rect width="1366" height="850" style="fill:rgb(0,0,0)" />
 </g>
 <script type="text/javascript" defer="true" ><![CDATA[
	  var SVGDocument = null;
      var SVGRoot = null;
      var TrueCoords = null;
      var GrabPoint = null;
      var BackDrop = null;
      var DragTarget = null;
      var width = 800;
      var height = 400;
      var gridLength = 20;
      var scale = 1;
      var svgPanel = null;
      function Init(evt){
         SVGDocument = evt.target.ownerDocument;
         SVGRoot = SVGDocument.documentElement;
         TrueCoords = SVGRoot.createSVGPoint();
         GrabPoint = SVGRoot.createSVGPoint();
         BackDrop = SVGDocument.getElementById("BackDrop");
         svgPanel = SVGDocument.getElementById("testdrag");
         if(document.addEventListener){
            document.addEventListener('DOMMouseScroll',scrollZoom,false);
         }
         window.onmousewheel=document.onmousewheel=scrollZoom;
		 document.documentElement.style.overflowY = 'hidden'; //???????
      }

      function scrollZoom(e){
          e=e || window.event;
          
		  if(isFirefox=navigator.userAgent.indexOf("Firefox")>0){  
				e.wheelDelta>0 || e.detail >0?zoom(0.9,e):zoom(1.1,e);
		  }else{
				e.wheelDelta>0 || e.detail >0?zoom(1.1,e):zoom(0.9,e);
		  }
      }

      function zoom(num,e){
        scale *= num;
        var sb = getMousePos(e);
        var sbx = sb.x;
        var sby = sb.y;
        svgPanel.setAttribute("transform-origin","0 0");
        svgPanel.setAttribute("transform","scale("+scale+"),translate(-"+sbx+",-"+sby+")");
      }

      function Grab(evt){
         var targetElement = svgPanel;
         if (BackDrop != targetElement){
            DragTarget = targetElement;
            DragTarget.parentNode.appendChild(DragTarget);
            DragTarget.setAttributeNS(null, "pointer-events", "none");
            var transMatrix = DragTarget.getCTM();
            GrabPoint.x = TrueCoords.x - Number(transMatrix.e);
            GrabPoint.y = TrueCoords.y - Number(transMatrix.f);
         }
      }; 

      function getMousePos(event) {              
        var e = event || window.event;              
        return {'x':e.clientX,'y':e.clientY} 
      } 

      function Drag(evt){
        GetTrueCoords(evt);
         if (DragTarget){
            var newX = TrueCoords.x - GrabPoint.x;
            var newY = TrueCoords.y - GrabPoint.y;
            DragTarget.setAttributeNS(null, "transform", "translate(" + newX + "," + newY + "),scale("+scale+")");
         }
      };

      function Drop(evt){
         if (DragTarget){
            var targetElement = svgPanel;
            DragTarget.setAttributeNS(null, "pointer-events", "all");
            if ("Folder" == targetElement.parentNode.id){
               targetElement.parentNode.appendChild( DragTarget );
            }
            else{}
            DragTarget = null;
         }
      };

      function GetTrueCoords(evt){
         var newScale = SVGRoot.currentScale;
         var translation = SVGRoot.currentTranslate;
         TrueCoords.x = (evt.clientX - translation.x)/newScale;
         TrueCoords.y = (evt.clientY - translation.y)/newScale;
      };  
	  ]]></script>
</svg>
相關文章
相關標籤/搜索