zoukankan      html  css  js  c++  java
  • 程式监控 小结(2)

    打印预览程序架构。

    因为规定要将监控的程序按装本系统监控的架构生成一个Tree样式的视图,还需要可以打印等功能。我也在网上找了好多方法没有什么简单方便的方法,要不就用第三方控件来实现,但是这个的花钱,要不就自己来画,来画出Tree的结构,我也试着画了,但是整到还不到一半头就大了,然后选择使用API的方法直接将控件的界面抓到图中,然后打印图形,结果发现这个方法效果太差。 没有办法了最后只有使用Web的方式来做了,因为用网页来实现这些很简单,起码不用我去控制分也什么,于是到网上找,找到一个.js文件,经过简单的改造后就可以很好的实现所要的功能,并且可以通过使用WebBrowse控件来调用IE自带的打印功能打印,下面将这个方法记录下来。


    该方法是使用一个叫dtree的js文件,这个文件主要用来生成树的方法,将由程序得到的数据写入到一个xml文件中,然后程序中调用WEbBrowse加载一个html,在该html中使用javascript读取xml文件并调用dtree中的类生成tree的结构。

    xml文件的格式为:


    <?xml version="1.0" encoding="utf-8" ?>
    <Root Name=" RootName" TitleName="RootName" Image="Image\0.png" FontSize="4" FontColor="red" Bold="true" Exp="true">
    <TreeItem Name="显示第一个节点 " Image="Image\1.png" FontSize="3" FontColor="Black" Bold="false" Exp="true">
    <TreeItem Name="第二个节点 " Image="Image\1.png" FontSize="3" FontColor="Black" Bold="false" Exp="true">
    <TreeItem Name="A01 [192.168.0.1]" Image="Image\2.png" FontSize="2" FontColor="Black" Bold="true" Exp="true">
    <TreeItem Name="test" Image="Image\5.png" FontSize="2" FontColor="Black" Bold="false" Exp="true">
    <TreeItem Name="1111.exe" Image="Image\17.png" FontSize="1" FontColor="red" Bold="false" Exp="true">
    <TreeItem Name="程式說明" FontSize="1" FontColor="Black" Bold="true" Exp="true" Image="img\page.gif">
    <TreeItem Name="XXXXXX" Image="img\empty.gif" FontColor="Black" Bold="false" Exp="true" FontSize="1" />
    </TreeItem>
    <TreeItem Name="2 [192.168.0.2]" FontColor="red" Bold="false" Exp="true" FontSize="2" Image="Image\3.png" />
    <TreeItem Name="4 [192.168.0.4]" FontColor="red" Bold="false" Exp="true" FontSize="2" Image="Image\3.png" />
    <TreeItem Name="6 [192.168.0.6]" FontColor="red" Bold="false" Exp="true" FontSize="2" Image="Image\3.png" />
    </TreeItem>
    <TreeItem Name="aa [192.168.0.2]" FontColor="red" Bold="false" Exp="true" FontSize="2" Image="Image\3.png" />
    </TreeItem>
    </Root>



    其中没有节点中都有自己的属性,比如Name:要显示的名称,Image:要显示的图标,FontSize:要显示的字体大小 FontColor:要显示的字体的颜色 Bold:是否粗体 Exp:是否可以展开。

    HTML文件:

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html>

    <head>
    <title>eConfigurationManager Tree Print View</title>
    <link rel="StyleSheet" href="dtree.css" type="text/css" />
    <script type="text/javascript" src="dtree.js"></script>
    <style>
    @media print {
    .noprint {display:none}
    }

    .fixedHead
    {
    position: relative;
    top: expression(this.offsetParent.scrollTop - 1);
    left: expression(this.offsetParent.scrollLeft - 1);
    }

    </style>
    </head>

    <body>

    <p>
    <table border="0" width="100%" id="table1" class="tb">
    <tr>
    <td>

    <h1 id="Ti" align="center">Title </h1><DIV style="PADDING-BOTTOM: 1px; BORDER-BOTTOM: 1px solid" align="right"><FONT face="宋体" id="tim"></FONT></DIV>
    </td>
    </tr>
    <tr>
    <td height="34" style="border-bottom-style: solid; border-bottom- 1px">
    <p><a href="javascript: d.openAll();" class="noprint">open all</a><font class="noprint"> | </font><a href="javascript: d.closeAll();" class="noprint">close all</a></p>
    <script type="text/javascript">
    <!--

    var d = new Date();
    window.document.all("tim").innerText = "文件產生時間:" + d.getFullYear() + "-" + (d.getMonth()+1) + "-" + d.getDate() + " " + d.getHours() + ":" + d.getMinutes() + ":" + d.getSeconds();
    var CurIndex = -1;
    var doc = new ActiveXObject("Msxml2.DOMDocument"); //ie5.5+,CreateObject("Microsoft.XMLDOM")
    var xmlFile ='data.xml';// window.location.href;
    doc.async =false;
    doc.load(xmlFile);

    var root = doc.selectSingleNode("//Root");
    var Title = root.selectSingleNode("@TitleName").text;
    window.document.all("Ti").innerText = Title;
    d = new dTree('d');
    var imagestr = root.selectSingleNode("@Image").text;
    var fontsize = root.selectSingleNode("@FontSize").text;
    var fontcolor = root.selectSingleNode("@FontColor").text;
    var fontBold;


    if(root.selectSingleNode("@Bold").text=="true")
    fontBold = true;
    else
    fontBold = false;

    var exp;
    if(root.selectSingleNode("@Exp").text =="true")
    exp = true;
    else
    exp = false;
    var index = GetIndex();
    //id, pid, name, url, title, target, icon, iconOpen, open, bold, color,size
    d.add(index,-1,root.selectSingleNode("@Name").text,'','','',imagestr,imagestr,exp,fontBold,fontcolor,fontsize);

    //获取root下的节点。
    var rootChild = root.selectNodes("TreeItem");
    var len = rootChild.length;

    for(var i=0;i<len;i++)
    {
    var node = rootChild[i];
    CreatNodes(node,index);
    }

    document.write(d);

    function CreatNodes(nodes,Pindex)
    {
    var namesub = nodes.selectSingleNode("@Name").text;
    var imagestrsub = nodes.selectSingleNode("@Image").text;
    var fontsizesub = nodes.selectSingleNode("@FontSize").text;
    var fontcolorsub = nodes.selectSingleNode("@FontColor").text;
    var fontBoldsub;


    if(nodes.selectSingleNode("@Bold").text=="true")
    fontBoldsub = true;
    else
    fontBoldsub = false;

    var expsub;
    if(nodes.selectSingleNode("@Exp").text =="true")
    expsub = true;
    else
    expsub = false;

    var indexnode= GetIndex();
    //id, pid, name, url, title, target, icon, iconOpen, open, bold, color,size

    d.add(indexnode,Pindex,namesub,'','','',imagestrsub,imagestrsub,expsub,fontBoldsub,fontcolorsub,fontsizesub);
    var nodesub = nodes.selectNodes("TreeItem");
    var len = nodesub.length;

    for(var i=0;i<len;i++)
    {
    var nodex = nodesub[i];
    CreatNodes(nodex,indexnode);
    }
    }

    function GetIndex()
    {
    CurIndex = CurIndex + 1;
    return CurIndex;
    }
    //-->
    </script>

     </td>
    </tr>
    </table></p>
    <p><b><a class="node" >&copy;2007-2008 </a></b></p>
    <!--
    <script language='JavaScript'>
    if (window.Event)
    document.captureEvents(Event.MOUSEUP);
    function nocontextmenu()
    {
    event.cancelBubble = true
    event.returnValue = false;
    return false;
    }
    function norightclick(e)
    {
    if (window.Event)
    {
    if (e.which == 2 || e.which == 3)
    return false;
    }
    else
    if (event.button == 2 || event.button == 3)
    {
    event.cancelBubble = true
    event.returnValue = false;
    return false;
    }
    }
    document.oncontextmenu = nocontextmenu; // for IE5+
    document.onmousedown = norightclick; // for all others
    </script> -->
    </body>

    </html>

    当加载html的时候就会去读取和html同目录下的data.xml文件了,同时调用dtree.js文件并生成tree视图了。

    剩下的工作就是使用Window编程将所有的信息保存成xml文件,同时自动获取每个程式的icon图标,并在预览的时候保存一份到img的目录下了,然后调用html就可以显示出来。显示界面效果。

    不过这个方法也有一个缺陷,当xml文件资料量过大的时候html加载过慢会照成一些影响。 因为我们监控的公司的程式很多,所以有时要是显示会有问题。不过还没有腾出时间来修改这个部分。我想可以通过重新设计html,可以设计成每次只显示部分,用户要看那个才去取得相关的xml文件,不过这样的话可能需要生成多个xml文件,没有程式对应一个,这样使用javascript读取会快些。


    点击下载相关文件


    效果图

















  • 相关阅读:
    AOP
    资料
    有用快捷键
    Java中getResourceAsStream的用法
    【转载】URL编码与两次encodeURI
    maven 如何使用
    MyEclipse运行Java出错:could not find the main class:test.program will exit(导入项目)
    java集合的操作(set,Iterator)
    java类集框架(ArrayList,LinkedList,Vector区别)
    java线程控制安全
  • 原文地址:https://www.cnblogs.com/zhucl1006/p/669747.html
Copyright © 2011-2022 走看看