博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[原]Winform自定义控件在网页上的应用
阅读量:7081 次
发布时间:2019-06-28

本文共 2552 字,大约阅读时间需要 8 分钟。

 

研究了一阵子C#版WorldWind,大家知道WorldWind是桌面程序,突然提了一个新需求,就是在IE里面运行WorldWind,对于java版的WorldWind来说可能比较容易,C#版的还真费神,我的做法是把WorldWindow以及自己的写的插件全部封装在一个winform自定义控件中,然后再把这个控件加载到webform上,效果非常好。

现在写一个简单的例子总结一下winform自定义控件在webform上使用的步骤。

一、制作winform自定义控件。

using
 System;
using
 System.Collections.Generic;
using
 System.ComponentModel;
using
 System.Drawing;
using
 System.Data;
using
 System.Text;
using
 System.Windows.Forms;
using
 System.Runtime.InteropServices;
namespace
 EventSourceCtrl
{
    
public delegate void Start(Boolean Restart);
    
public delegate void Stop();
    
public delegate void Pause();
    [GuidAttribute(
"1A585C4D-3371-48dc-AF8A-AFFECC1B0967")]
    [InterfaceTypeAttribute(ComInterfaceType.InterfaceIsIDispatch)]
    
public interface ButtonEvents
    
{
        [DispId(
0)]
        
void DoStart(Boolean Restart);
        [DispId(
1)]
        
void DoStop();
        [DispId(
2)]
        
void DoPause();
    }
    
public interface IDoNetEventInScript
    
{
        
void SetCaption(string Value);
    }
    [ComVisible(
true)]
    [ClassInterface(ClassInterfaceType.None)]
    [ComSourceInterfaces(
typeof(ButtonEvents))]
    [Guid(
"5649B9CC-07BA-432a-A392-532EE2AFD190")]
    
public partial class sourceCtrl : UserControl, IDoNetEventInScript
    
{
        
public event Start DoStart;
        
public event Stop DoStop;
        
public event Pause DoPause;
        
public sourceCtrl()
        
{
            InitializeComponent();
        }
        
private void button1_Click_1(object sender, EventArgs e)
        
{
            
if (DoStart != null)
            
{
                DoStart(
true);
            }
        }
        
private void button2_Click(object sender, EventArgs e)
        
{
            
if (DoPause != null)
            
{
                DoPause();
            }
        }
        
private void button3_Click(object sender, EventArgs e)
        
{
            
if (DoStart != null)
            
{
                DoStart(
false);
            }
        }
        
private void button4_Click(object sender, EventArgs e)
        
{
            
if (DoStop != null)
            
{
                DoStop();
            }
        }
        
IDoNetEventInScript 成员#region IDoNetEventInScript 成员
        
public void SetCaption(string Value)
        
{
            label1.Text 
= Value;
        }
        
#endregion
    }
}

超级简单的一个例子,没什么好说的,要注意的是控件类前面的几个属性[ComVisible(true)][Guid("5649B9CC-07BA-432a-A392-532EE2AFD190")]是必须的。

 

二、Visual Studio 2005命令提示注册控件到全局缓存,注意用windowscmd.exe进行注册不行,不认识命令。

注册命令是:regasm /codebase fullpath,其中codebase是必须的,要不然即使注册成功也不会在IE上显示。如图:

三、将注册好的控件放在网页上

<
html
>
    
<
head
>
        
<
title
>
DotNetEventInScript
</
title
>
    
</
head
>
    
<
body
>
        
<
object 
id
= "eventSource"
classid
="clsid:5649B9CC-07BA-432a-A392-532EE2AFD190"
 width
=100% 
height
=100% 
align
=alClient
>
        
</
object
>
        
<
script 
type
="text/javascript"
>
            
function eventSource::DoStart(Restart)
            
{
                alert(
"DoStart");
            }
            
function eventSource::DoStop()
            
{
                alert(
"DoStop");
            }
            
function eventSource::DoPause()
            
{
                alert(
"DoPause");
            }
        
</
script
>
    
</
body
>
</
html
>

测试看看,效果不错吧!

转载于:https://www.cnblogs.com/salonliudong/archive/2008/03/06/1093426.html

你可能感兴趣的文章
新书问答:Agile Management
查看>>
精益企业中架构师的角色
查看>>
Chrome开发者工具中关于“Deferred long-running timer task(s) ”的警告
查看>>
Windows 下使用 MinGW 编译安装 (G)vim 添加 Lua 等编程语言支持
查看>>
Objective-C基本数据类型
查看>>
利用localStorage本地储存js文件
查看>>
[聊一聊系列]聊一聊百度移动端首页前端速度那些事儿
查看>>
shell script编程小结——附带实例
查看>>
在 Laravel 项目中使用 Glup 之 Laravel-Elixir
查看>>
Nginx、CGI、FastCGI、PHP-CGI、PHP-FPM处理流程
查看>>
Tornado 4.3文档翻译: web框架-RequestHandler和Application 类
查看>>
版本控制总结
查看>>
数字证书、公私钥小记
查看>>
客户端开发流程
查看>>
Javascript基础之-Promise
查看>>
报名 | 清华方圆系列之大数据分析与可视化报告会将于下周举办
查看>>
了解 php.ini
查看>>
异地容灾方案解析
查看>>
深入理解Vue的生命周期
查看>>
WPF's Style BasedOn
查看>>