java调用ocx控件(ActiveX控件),SWT调用ocx(ActiveX)

2 篇文章 0 订阅
2 篇文章 0 订阅

java调用ocx控件(ActiveX控件),SWT调用ocx(ActiveX)

注 : OLE、OCX、ActiveX不进行过多阐述,简单理解就是插件,组件类
调用成功,即可展示ocx对应的窗口
​ java调用ocx窗口
文档结尾附我使用的jvm ,swt.jar包及下载swt.jar包地址

直接上代码,复制粘贴修改对应的ClassID,方法名,参数,DispatchID即可使用
  1. 创建 ActiveXUtil 类,简单说就是一个Ole的工具类,将初始化方法,调用ocx方法放在一个util中

    import org.eclipse.swt.SWT;
    import org.eclipse.swt.ole.win32.OleAutomation;
    import org.eclipse.swt.ole.win32.OleControlSite;
    import org.eclipse.swt.ole.win32.OleFrame;
    import org.eclipse.swt.ole.win32.OleListener;
    import org.eclipse.swt.ole.win32.Variant;
    import org.eclipse.swt.widgets.Shell;
    
    public class ActiveXUtil {
        private Shell _shell;//弹窗
        private OleFrame _frame; //一个放置ole控件的面板
        private OleControlSite _site;//ActiveX控件(即插件 注 : OleClientSite为OLE控件)
        private OleAutomation _auto;//Ole自动服务器,编写能被其他程序调用的代码
    
        public Shell getShell() {
            return _shell;
        }
    
        public OleFrame getFrame() {
            return _frame;
        }
    
        public OleControlSite getSite() {
            return _site;
        }
    
        public OleAutomation getAuto() {
            return _auto;
        }
    
        //请求 OLE 对象执行其中一个可用的动作 OLE 对象—激活其内容所需的操作
        public int doVerb(int verb) {
            return _site.doVerb(verb);
        }
    
        //构造方法,进行窗口初始化
        ActiveXUtil(String activexId, OleControlSite site, Shell shell) {
            if (site == null) {
                _shell = (shell == null ? new Shell() : shell);
                _frame = new OleFrame(_shell, SWT.NONE);
                _site = new OleControlSite(_frame, SWT.NONE, activexId);
                _auto = new OleAutomation(_site);
            } else {
                _site = site;
                _auto = new OleAutomation(site);
            }
        }
    
        //根据控件中的方法名获取对应的disId
        public int getID(String name) {
            try {
                int[] ids = _auto.getIDsOfNames(new String[] { name });
                if (ids.length >= 0)
                    return ids[0];
            } catch (RuntimeException e) {
                e.printStackTrace();
            }
            return -1;
        }
    
        public Variant[] createVariants(String[] paras) {
            Variant[] vr = new Variant[paras.length];
            for (int i = 0; i < paras.length; i++) {
                vr[i] = new Variant(paras[i]);
            }
            return vr;
        }
    
        public Variant getProperty(String prop) {
            int propId = getID(prop);
            Variant v = null;
            try {
                v = _auto.getProperty(propId);
            } catch (Exception e) {
                e.printStackTrace();
            }
            return v;
        }
    
        public void setProperty(String name, String... params) {
            int propId = getID(name);
            if (propId < 0)
                return;
            if (params.length == 1)
                _auto.setProperty(propId, new Variant(params[0]));
            else {
                Variant[] vs = new Variant[params.length];
                int i = 0;
                for (String param : params) {
                    vs[i] = new Variant(param);
                    i++;
                }
                _auto.setProperty(propId, vs);
            }
        }
    
        public void setProperty(String name, Variant... params) {
            int propId = getID(name);
            if (propId < 0)
                return;
            _auto.setProperty(propId, params);
        }
    
        public Variant execute(String methodName, Variant... params) {
            int mid = getID(methodName);
            if (mid < 0)
                return null;
            Variant rtnv;
            if (params == null)
                rtnv = _auto.invoke(mid);
            else
                rtnv = _auto.invoke(mid, params);
            return rtnv;
        }
    
        public Variant execute(String methodName) {
            int mid = getID(methodName);
            if (mid < 0)
                return null;
    
            Variant rtnv = _auto.invoke(mid);
            return rtnv;
        }
    
        public void addEventListener(int eventID, OleListener listener) {
            _site.addEventListener(eventID, listener);
        }
    
        public void removeEventListener(int eventID, OleListener listener) {
            _site.removeEventListener(eventID, listener);
        }
    
    }
    
  2. 创建调用ocx的类

    import org.eclipse.swt.SWT;
    import org.eclipse.swt.events.SelectionAdapter;
    import org.eclipse.swt.events.SelectionEvent;
    import org.eclipse.swt.layout.RowLayout;
    import org.eclipse.swt.ole.win32.OLE;
    import org.eclipse.swt.ole.win32.OleEvent;
    import org.eclipse.swt.ole.win32.OleListener;
    import org.eclipse.swt.ole.win32.Variant;
    import org.eclipse.swt.widgets.Button;
    import org.eclipse.swt.widgets.Display;
    import org.eclipse.swt.widgets.Shell;
    
    public class SwtOcx {
    
        public static void main(String[] args) {
            // 设置应用标题
            Display display = Display.getDefault();
            Shell shell = new Shell();
            shell.setSize(900, 760);
            shell.setLayout(new RowLayout());
            shell.setText("调用ocx程序");
    
            // 初始化ActiveX控件
            final ActiveXUtil util = new ActiveXUtil("{8975B773-7CF3-4C4C-B646-DA9F6A154260}", null, shell);//ClassID
            util.getFrame().setSize(shell.getClientArea().width, shell.getClientArea().height);
            util.doVerb(OLE.OLEIVERB_SHOW);
    
            //监听事件
            final int nEventXXX = 210;// 某事件ID,使用工具查看事件的DispatchID
            util.addEventListener(nEventXXX, new OleListener() {
                @Override
                public void handleEvent(OleEvent event) {
                    System.out.println(event.arguments[0].getString());
                    //监听事件对应的数据,打印
                }
            });
    
            // 调用方法
            Button button1 = new Button(shell, SWT.PUSH);
            button1.setText("调用OCX方法");
            button1.addSelectionListener(new SelectionAdapter() {
                public void widgetSelected(SelectionEvent e) {
                    Variant result = util.execute("mothed", new Variant(
                            "参数"));//mothed为要调用的插件内的方法名 , 方法中的入参用new Variant("参数")进行传输,,多个参数则new 多个Variant
    
                    if (result == null) {
                        System.out.println("ActiveX method failure!");
                    }
                }
            });
    
            // 显示窗口
            shell.setSize(900, 800);
            shell.open();
            shell.layout();
    
            while (!shell.isDisposed()) {
                if (!display.readAndDispatch()) {
                    display.sleep();
                }
            }
        }
    
    }
    
    1. 操作过程中报错解答

      1. UnsatisfiedLinkError: Cannot load 64-bit SWT libraries on 32-bit JVM
        在这里插入图片描述
        32位的JVM不能使用64位的SWT,修改对应的JVM或者SWT即可

      2. org.eclipse.swt.SWTException: Failed to create Ole Client. result = -2147221164
        在这里插入图片描述

      具体原因没有排查,但是肯定是出在ocx,jar包和JVM之前的关系不匹配,此处我是使用32位的OCX,然后是org.eclipse.swt.win32.win32.x86_64-4.6.jar包,64位的JVM报的这个错,不用多想,肯定是三者之间不匹配,多换jar包,jvm即可

      1. org.eclipse.swt.SWTException: Class ID not found in registry
        在这里插入图片描述

      ClassID不对,若确定classid正确,可能是你没有加{},此处我是直接拷贝的8975B773-7CF3-4C4C-B646-DA9F6A154260,报错后加上{}后即可{8975B773-7CF3-4C4C-B646-DA9F6A154260}

      4)在这里插入图片描述
      空指针,方法名,参数,参数个数总有一个是错误,核查解决即可

      5)监听事件出不来数据,DispatchID不对,去检查DispatchID

调用成功后 ,窗口展示情况

在这里插入图片描述
** 附 : swt32位.jar包 失效留言重新发**
链接: https://pan.baidu.com/s/1o7EOnMM5BU8Z2BC2TaiODQ 提取码: x6dj 复制这段内容后打开百度网盘手机App,操作更方便哦
**附 : 32位jdk1.7 **
链接: https://pan.baidu.com/s/1GtsJPrKVxpQD9ps9vx2v6g 提取码: 97wq 复制这段内容后打开百度网盘手机App,操作更方便哦
**附 : swt包下载地址 : https://repo1.maven.org/maven2/swt/ **

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: 谷歌浏览器(Google Chrome)是一款目前应用广泛的网页浏览器,用于访问互联网上的各种网页内容。与其他浏览器相比,谷歌浏览器具有更快的网页加载速度、强大的安全性和用户体验。 在使用谷歌浏览器浏览网页时,有时候我们会遇到需要调用OCX(Object Control Extension,对象控件扩展)控件的情况。OCX是一种在Windows操作系统上运行的二进制对象控件,与ActiveX控件类似,用于增强浏览器的功能。 当谷歌浏览器需要调用OCX控件时,它会按照预设的规则查找并加载相应的控件,以确保能够正确执行相应的功能。这些OCX控件通常由开发者或第三方提供,并根据需要引入谷歌浏览器中。一旦OCX控件加载成功,谷歌浏览器就能够使用该控件提供的功能,例如播放音频、视频、处理文件上传等。 在调用OCX控件时,谷歌浏览器会检查控件的完整性和安全性,以确保它不会对用户的计算机造成损害。这是出于安全考虑,以防止潜在的恶意代码对用户的计算机进行攻击或非法操作。 需要注意的是,有些OCX控件可能不被谷歌浏览器支持,或者由于安全限制而不容许使用。在这种情况下,用户可能需要通过其他方式来完成相应的功能,或者尝试使用其他浏览器来满足需求。 总之,谷歌浏览器能够调用OCX控件来扩展其功能,提供更好的用户体验和网页交互。这也体现了谷歌浏览器的灵活性和开放性,以适应不同用户的需求。 ### 回答2: 谷歌浏览器不支持直接调用OCX控件OCX控件(包括ActiveX控件)是一种用于Windows环境下的特殊组件,主要用于在网页中显示多媒体内容或执行其他特定任务。然而,由于谷歌浏览器采用了Chromium内核,该内核与传统的OCX控件不兼容,因此无法直接调用OCX控件。 为了解决这个问题,开发者可以考虑使用其他替代方案。例如,可以使用基于HTML5的原生Web浏览器 API来实现类似功能。HTML5提供了一系列的标准API,如Canvas、WebRTC、Web Audio等,可以用于实现图像处理、音视频播放等功能,从而不再依赖于OCX控件。 此外,如果必须使用OCX控件,用户可以考虑切换到支持OCX控件的浏览器,如Internet Explorer。在Internet Explorer中,用户可以直接调用和使用OCX控件,以实现特定功能。 总之,谷歌浏览器无法直接调用OCX控件,但开发者可以通过使用HTML5的相关API或切换到支持OCX控件的浏览器来实现类似的功能。 ### 回答3: 谷歌浏览器可以通过调用OCX控件实现一些特定功能。OCX(Object Linking and Embedding Control)是一个可重复使用的软件组件,它可以被嵌入在其他应用程序中,并提供特定的功能。 在谷歌浏览器中,当需要使用OCX控件时,首先需要在相关的网页或应用程序中引用该控件。通过添加控件的相关代码,谷歌浏览器就能够了解如何调用和使用该控件。 一旦OCX控件调用,谷歌浏览器可以利用该控件的特定功能。例如,如果OCX控件是用于媒体播放的,谷歌浏览器就能够播放网页上嵌入的音频或视频文件。如果OCX控件是用于动画或特效的,谷歌浏览器也能够展示出这些特效。 谷歌浏览器调用OCX控件的过程是通过调用接口、方法或事件来实现的。OCX控件会提供一系列的接口或方法,用于与谷歌浏览器进行交互。谷歌浏览器可以根据需要调用这些接口或方法,以实现业务逻辑的功能。 总结来说,谷歌浏览器调用OCX控件是通过添加需要使用的控件代码,并通过调用接口、方法或事件等方式与控件进行交互。这样可以为用户提供更丰富的浏览器功能和体验。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值