前段时间继续下来的基于Skyline的B/S项目,是基于Terra Explorer6.6实现的。项目中涉及到基于三维模型查询设备编码等操作,从用户友好角度来讲,查询到的设备编码应该要支持复制,方便用户基于编码的二次查询和操作。

1. Terra Explorer弹出窗口限制

通常来说,在浏览器中复制页面内容,是由浏览器右键支持的,虽然格式和内容我们不能定制,但是也能满足要求。但是在TE弹出不支持右键复制,右键菜单有,但是内容复制不出来。

2. clipboard.js轻量级实现剪切板js插件

clipboard.js 是一个不需要flash,将文本复制到剪贴板的js插件。用法很简单,这里使用其中的一种方法:

    <!--html代码-->
<button id="mapclipboard_btn" data-clipboard-action="copy" data-clipboard-text="">复制</button>
    //实例化剪切板对象
var clip = new Clipboard('#mapclipboard_btn');

这种形式的使用思路是,触发mapclipboard_btn按钮的click事件后,clipboardJS插件将data-clipboard-text属性的内容复制到剪切板。这样我们可以在触发按钮click事件前,设置好要复制到剪切板的内容。

3. 结合cliboard.js的Terra Explorer弹出窗口剪切板功能实现

这里我们使用clipboardJS插件,结合TE的消息机制实现弹出窗口剪切板功能。

首先,在主页面中加入2中代码,实例化剪切板对象;

其次,在TE弹出窗口,增加复制按钮,并在触发复制按钮时,使用TE接口发送复制文本消息;

<!--弹出窗口复制按钮-->
<input id="text" style="width: 55%; height: 20px;"/>
<button id="copy" style="width: 35%; height: 25px;">
复制
</button> //复制按钮单击事件
$("#copy").click(function () {
var text = $("#text");
sgworld.Window.ShowMessageBarText(text);
});

最后,在主页面中添加消息处理代码,添加剪切板内容

sgworld.AttachEvent("OnSGWorldMessage", function (messageId, sourceObjectId) {
var clipboardText = messageId;
$("#mapclipboard_btn").attr("data-clipboard-text", clipboardText);
$("#mapclipboard_btn").trigger("click");
return true;
}

如果OnSGWorldMessage已经在使用,可以通过条件消息类型的方式与其他消息进行区分。至此,就实现了TE6.6中弹出窗口简单的剪切板功能。

4. 7.0.1已经支持弹出窗口内容的复制

在写这篇博客时由于要使用TE7.0.1的新特性和功能,系统已经升级到TE7.0.1。顺手一点右键复制,发现是有效的。看来老外也注意到了这个问题,已经解决了。虽然右键复制不是那么友好,无法定制格式和内容,但是毕竟可以选什么复制什么,也算是很实用的。

写在最后

最近早上上班总要把博客园首页感兴趣的最多推荐、最多评论、新闻头条、推荐新闻看一下。一方面是因为手头项目越来越让人头疼,陷入了孤军奋战、推进困难的窘境。另一方面也在想转眼自己已经工作将近五年了,也要迈入30岁了,有点焦虑。总觉得自己技术还可以,学习能力还不错,但是第一次跳槽后,总感觉再也找不到适合自己的工作了。一年有大半年在外出差,现场开发、调试,租的房子好像就是用来放行李的。每每回到自己base地,躺在床上,总不想再出差了。

出差与不出差的交织,也使本来就定力不好的我,变得懒惰,形不成好的习惯。每每是刚刚习惯了跑步,刚刚学个新东西到了一半,就会被出差或者回公司打断。回头看看在园子里转了5年,也没有留下些什么,自己也不知道自己沉淀了什么,积累了什么。于是,总想写点什么,不知道是担心,还是想发泄。

真的不想一个人,很怀念刚工作的时候。6、7个人住在北京的两室一厅,一起上下班,一起玩游戏,一起学习,玩的快乐,工作有劲,相互学习,相互进步。

Skyline Terra Explorer6.6弹出窗口实现复制功能的更多相关文章

  1. jQuery弹出窗口浏览图片

    效果预览:http://keleyi.com/keleyi/phtml/jqtexiao/3.htm HTML文件代码: <!DOCTYPE HTML> <html> < ...

  2. EasyUI弹出窗口实例

    效果体验:http://hovertree.com/texiao/jeasyui/1.htm 源代码下载:HovertreeJEasyUI HTML文件代码: <!DOCTYPE html> ...

  3. 让IE8在win7下面能显示使用window.showmodaldialog弹出窗口的地址状态栏

    问题来源:最近又要对老的系统进行改善,由于用到了window.showmodaldialog这个方法弹出窗口,比如从主界面弹出新增或者修改窗口,如下图所示,显示没有地址栏,进行代码修改还要找到相应的文 ...

  4. java selenium (十二) 操作弹出窗口

    selenium 中如何处理弹出窗口 阅读目录 原理 在代码里, 通过         Set<String> allWindowsId = driver.getWindowHandles ...

  5. JSP弹出窗口和模式对话框

    本文转载于其它blog,在此向本文原创者,致意!    JSP 弹出窗口  一.window.open() 基础知识      1.window.open()支持环境:  JavaScript1.0+ ...

  6. [转]js来弹出窗口的详细说明

    1.警告对话框 <script> alert("警告文字") </script> 2.确认对话框 <script> confirm(" ...

  7. OAF_开发系列08_实现OAF通过Popup参数式弹出窗口(案例)

    20150711 Created By BaoXinjian

  8. 【CefSharp】 禁用右键菜单 与 控制弹出窗口的方式(限版本39.0.0.1)

    这周没什么时间,一开始就在忙一些CefSharp的事情,Win10的研究就放了下来,CefSharp的资料挺少的,但好在是开源的,可以我们便宜的折腾.因为两个的内容都不多,我就合成一篇文章啦. 这还里 ...

  9. jquery-通过js编写弹出窗口

    本文转载 本文主要是通过js动态控制div的高度,css控制浮动 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional// ...

随机推荐

  1. 使用强类型实体Id来避免原始类型困扰(一)

    原文地址:https://andrewlock.net/using-strongly-typed-entity-ids-to-avoid-primitive-obsession-part-1/ 作者: ...

  2. VS2017、VS2019没有Setup安装项目(Visual Studio Installer)_解决方案

    前言: VS2010中有一个自带的安装部署项目,叫:Visual Studio Installer ,我们通常称为:setup项目,是一个用于自定义安装部署的项目方案.但是在VS2017,VS2019 ...

  3. d3实现家族树

      1.  jQuery和CSS3支持移动手机的DOM元素移动和缩放插件:panzoom   2.拖动:jqueryUI-Draggable.touchpunch   3.图表:echart.heig ...

  4. Hi3516EV300专业型HD IP Camera SoC

    Hi3516EV300芯片特点: 处理器内核 ARM Cortex A7@ 900MHz,32KB I-Cache,32KB D-Cache /128KB L2 cache 支持 Neon 加速,集成 ...

  5. 在Hyper-V上安装RemixOS 的Android模拟器

    不想用实体机,想不想弄个快速的Android虚拟环境,今天我们就来说说把Android模拟器(RemixOS)安到Hyper-v上的办法. 1. 下载RemixOs  或者直接去 论坛获得下载地址 2 ...

  6. 编程心法 之 敏捷开发(新架构)Agile Team Organization Squads, Chapters, Tribes and Guilds

    Agile Team 参考 一般情况下,一个小组有以下功能分布: Squads 每个主要的功能的开发属于一个Squad,比如说QQ这个应用,可以分为QQ空间小组.QQ会员小组等等, 每一个Squad有 ...

  7. idea上maven使用心得(三)——用pom.xml添加jar包

    下面是如何使用maven,maven在idea里面得结构应该是这样: scr底下是main,java是存放web的.java文件 resource目录一般是存放数据库连接数据的,或者存各种资源文件,音 ...

  8. Variable SQLLOGDIR not found

    昨天在一数据库(SQL Server 2008 R2 SP3)上部署了一个作业,今天早上收到告警邮件,作业执行报错"Unable to start execution of step 1 ( ...

  9. CSS Sprites(基本写法,怎样使用)

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/XTQueen_up/article/details/37601361 说白就是用样式表切一个大图片 ...

  10. Linux 桌面玩家指南:03. 针对 Gnome 3 的 Linux 桌面进行美化

    特别说明:要在我的随笔后写评论的小伙伴们请注意了,我的博客开启了 MathJax 数学公式支持,MathJax 使用$标记数学公式的开始和结束.如果某条评论中出现了两个$,MathJax 会将两个$之 ...