C#进行Visio二次开发之Web查看Visio图纸

前面介绍的Visio开发知识,都是基于Winform的Visio的开发知识,图纸的展示都是基于Winform方式展示的。但很多时候,如果能够通过Web方式可以查看最新的图纸信息,那么系统将更加趋向完美,你说是不是呢?
通过Web方式查看Visio图纸实现起来也是很容易的,首先需要在IE客户端安装一个Visio Viewer的ActiveX控件支持(微软提供),然后剩下来的就是编码展示了,展示的方式和其他的ActiveX控件展示方式差不多。先看看总体的界面实现思路,让大家有一个较好的理解后,然后我们在一步步分析如何实现。
ViewVisio1.jpg
单击查看馈线图的按钮后,新开一个窗口展示Visio的图纸(是不是和Winform看到的效果差不多呢?呵呵)
ViewVisio2.jpg

下面介绍下如何实现这个功能:
1、第一个页面的实现很简单,你指定一个链接指向新的页面(VisioContainer.aspx),该页面包含Visio View的ActiveX控件,连接中带一些参数过来,指明是查看那个图纸的就OK了。
2、这个页面(VisioContainer.aspx)实现很关键,在此页面放置一个Visio Viewer的ActiveX控件,这个控件最重要的一个变量是SRC,它需要指向一个Visio的文件路径,如果Visio图纸是文件的话,直接赋值就可以显示了。但是,我们的系统是基于数据库存储的,所有的Visio图纸都是已二进制的方式存储在数据库的,那该如何实现呢?先看页面代码

ContractedBlock.gif ExpandedBlockStart.gif Code
    <form id="Form1" runat="server">
        
<div>
            
<div align="right" style="font-size:x-small">如图纸不能正常显示,请<href="http://www.cnblogs.com/Visio/Visio Viewer 2003.exe">下载安装Visio Viewer2003</a></div>
            
<object id="Viewer1" codebase="http://www.cnblogs.com/Visio/Visio Viewer 2003.exe" height="100%" width="100%"
                classid
="clsid:279D6C9A-652E-4833-BEFC-312CA8887857" viewastext>
                
<param name="_cx" value="31485">
                
<param name="_cy" value="20373">
                
<param name="BackColor" value="16777200">
                
<param name="AlertsEnabled" value="-1">
                
<param name="ContextMenuEnabled" value="-1">
                
<param name="GridVisible" value="0">
                
<param name="HighQualityRender" value="-1">
                
<param name="PageColor" value="16777215">
                
<param name="PageVisible" value="-1">
                
<param name="PropertyDialogEnabled" value="-1">
                
<param name="ScrollbarsVisible" value="-1">
                
<param name="SizeGripVisible" value="-1">
                
<param name="ToolbarVisible" value="-1">
                
<param name="SRC" value="">
                
<param name="CurrentPageIndex" value="0">
                
<param name="Zoom" value="-1">
                
<param name="PageTabsVisible" value="-1">
                
<param name="ToolbarButtons" value="">
                
<param name="ToolbarCustomizable" value="-1">
            
</object>
        
</div>
    
</form>

其中我们需要动态指定SRC的值,因此在页面(VisioContainer.aspx)后台代码中动态绑定了,这里我们使用了JavaScript的方式来加载Visio Viewer 的SRC路径信息。
ContractedBlock.gif ExpandedBlockStart.gif Code
    protected void Page_Load(object sender, EventArgs e)
    {
        
string VisioID= Request.QueryString["VisioID"];
        StringBuilder sb 
= new StringBuilder();
        sb.Append(
"<script language='javascript'>");
        sb.AppendFormat(
"Form1.Viewer1.src = 'VisioFile.aspx?VisioID={0}'", System.Web.HttpUtility.UrlEncode(VisioID));
        sb.Append(
"</script>");
        ClientScript.RegisterStartupScript(
typeof(string),"loadvisio", sb.ToString());
    }

我们通过一个新的页面 VisioFile.aspx来动态生成Visio文件,然后赋值给SRC属性即可实现了。
VisioFile.aspx的页面只需要实现PageLoad函数即可,如下所示
ContractedBlock.gif ExpandedBlockStart.gif Code
    private void Page_Load(object sender, System.EventArgs e)
    {
            
string VisioID = Request.QueryString["VisioID"];

            
if (VisioID != null)
            {
                VisioImageRelease VisioImage 
= new VisioImageRelease();
                
using (IDataReader dr = VisioImage.GetByVisioID(VisioID))
                {
                    dr.Read();
                    
byte[] visioImage = (byte[])dr["visioImage"];
                    OutputVisioFile(visioImage);
                }
            }
    }

    
/// <summary>
    
/// 输入Visio文件到流
    
/// </summary>
    
/// <param name="visioFile">Visio文件字节数组</param>
    private void OutputVisioFile(byte[] visioFile)
    {
        Response.ContentType 
= "application/vnd.ms-visio.viewer";
        Response.OutputStream.Write(visioFile, 
0, visioFile.Length);
        Response.Flush();
        Response.End();
    }

这样我们就可以实现Web端展示Visio图纸的功能了。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值