eas之事件
选择事件
选择事件是在选择块发生变化后发出。
table.addKDTSelectListener(new KDTSelectListener()
{
public void tableSelectChanged(KDTSelectEvent e){
// 获取上一个选择块
KDTSelectBlock sbPrev = e.getPrevSelectBlock();
// 获取当前选择块
KDTSelectBlock sbCurr = e.getSelectBlock();
// ...do something
}
});
鼠标单击双击事件
单击事件是在鼠标单击某个单元格后发出。
双击事件是在鼠标双击某个单元格后发出。
table.addKDTMouseListener(new KDTMouseListener()
{
public void tableClicked(KDTMouseEvent e)
{
// 单击
if (e.getClickCount() == 1)
{
// ...do something
}
// 双击
else if (e.getClickCount() == 2)
{
// ...do something
}
}
});
激活单元即指当前处于准备进入编辑状态的单元。
激活单元变化事件是在激活单元发生变化后发出。
添加激活单元变化事件侦听者
table.addKDTActiveCellListener(new KDTActiveCellListener()
{
public void activeCellChanged(KDTActiveCellEvent e)
{
// 获取上一个激活单元的行列索引
int prevRow = e.getPrevRowIndex();
int prevCol = e.getPrevColumnIndex();
// 获取当前激活单元的行列索引
int currRow = e.getRowIndex();
int currCol = e.getColumnIndex();
// ...do something
}
});
编辑事件
编辑事件KDTEditListener包括以下几个方法:
editStarting 编辑器启动中,在编辑器启动之前发出,通过设置返回值可以取消启动编辑器。
editStarted 编辑启动后,在编辑启动之后发出。
editValueChanged 编辑器值变化,在编辑器的值发生变化后发出。
editStopping 编辑器结束中,在编辑器结束之前发出,通过设置返回值可以取消结束编辑器。
editStopped 编辑器结束后,在编辑器结束之后发出。
KDTEditListener提供了适配器KDTEditAdapter
// 示例
table.addKDTEditListener(new KDTEditAdapter()
{
// 编辑器启动前
public void editStarting(KDTEditEvent e)
{
System.out.println("editStarting");
// 如果当前行是第三行,将取消编辑
if (e.getRowIndex() == 3)
e.setCancel(true);
}
// 编辑启动后
public void editStarted(KDTEditEvent e)
{
System.out.println("editStarted");
// 如果当前单元处于第4行第0列,并且单元值为字符串,则在字符串前加上$符
if ((e.getRowIndex() == 4) && (e.getColIndex() == 0))
{
KDTable tbl = (KDTable)e.getSource();
Object value =tbl.getEditManager().getEditor().getValue();
if (value instanceof String)
tbl.getEditManager().getEditor().setValue("$" + value.toString());
}
}
// 编辑器值变化(注意:此时编辑器还未结束,KDTable实际上是转发编辑器的
// change事件)
public void editValueChanged(KDTEditEvent e){
System.out.println("editValueChanged");
}
// 编辑器结束前
public void editStopping(KDTEditEvent e)
{
System.out.println("editStopping");
//如果当前单元处于第4行第0列,则在退出前将$符去掉
if ((e.getRowIndex() == 4) && (e.getColIndex() == 0))
{
KDTable tbl = (KDTable)e.getSource();
String value = (String)tbl.getEditManager().getEditor().getValue();
// 如果单元格的值长度小于5,则不允许退出编辑状态
if (value.length() < 5)
e.setCancel(true);
// 否则,取得$符并退出编辑
else
tbl.getEditManager().getEditor().setValue(value.substring(1, value.length()));
}
}
// 编辑结束后
public void editStopped(KDTEditEvent e) {
System.out.println("editStopped");
}
});
BeforeActionListener事件
这个事件在table增删行列以及copy、paste、cut时触发,通过设置事件参数的返回值可以取消相应的动作。
// 给table设置action
table.setBeforeAction(new TableBeforeAction());
// action的实现
class TableBeforeAction implements BeforeActionListener
{
/**
*@see com.kingdee.bos.ctrl.kdf.table.event.BeforeActionListener#beforeAction(com.kingdee.bos.ctrl.kdf.table.event.BeforeActionEvent)
*/
public void beforeAction(BeforeActionEvent e)
{
// 添加行
if (e.getType() == BeforeActionEvent.ACTION_ADD_ROW)
{
// 获取插入行的位置
int rowIndex = ((Integer)e.getParameter()).intValue();
if (rowIndex > 5)
{
WindowUtil.msgboxInfo("不能添加行", "title", table);
// 取消动作
e.setCancel(true);
}
}
// 添加列
else if (e.getType() == BeforeActionEvent.ACTION_ADD_COLUMN)
{
int colIndex = ((Integer)e.getParameter()).intValue();
if (colIndex > 3)
{
WindowUtil.msgboxInfo("不能添加列", "title", table);
// 取消动作
e.setCancel(true);
}
}
// paste
else if (e.getType() == BeforeActionEvent.ACTION_PASTE)
{
// 获取paste的项
int mark = ((Integer)e.getParameter()).intValue();
// 如果paste项中包含userObject,则
if (KDTEditHelper.isUserObject(mark))
{
WindowUtil.msgboxInfo("paste", "title", table);
// paste除userObject外的内容
table.getEditHelper().paste(KDTEditHelper.STYLE | KDTEditHelper.VALUE | KDTEditHelper.FORMULA);
// 取消动作
e.setCancel(true);
}
}
// cut
else if (e.getType() == BeforeActionEvent.ACTION_CUT)
{
// 获取cut的项
int mark = ((Integer)e.getParameter()).intValue();
// 如果cut项中包含userObject,则
if (KDTEditHelper.isUserObject(mark))
{
WindowUtil.msgboxInfo("cut", "title", table);
// cut除userObject外的内容
table.getEditHelper().paste(KDTEditHelper.STYLE | KDTEditHelper.VALUE | KDTEditHelper.FORMULA);
// 取消动作
e.setCancel(true);
}
}
}
}
eas之事件的更多相关文章
- JNI详解---从不懂到理解
转载:https://blog.csdn.net/hui12581/article/details/44832651 Chap1:JNI完全手册... 3 Chap2:JNI-百度百科... 11 C ...
- eas中删除原来的监听事件添加新的监听事件
kdtEntrys.removeKDTEditListener(kdtEntrys.getListeners(KDTEditListener.class)[0]); kdtEntrys.addKDT ...
- JQuery事件机制
1 事件操作 1.1 页面载入事件 $(document).ready(function(){ // 在这里写你的代码... }); 或者 $(function($) { // 你可以在这里继续使用$ ...
- Jquery的点击事件,三句代码完成全选事件
先来看一下Js和Jquery的点击事件 举两个简单的例子 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN&q ...
- 关于 Chrome 浏览器中 onresize 事件的 Bug
我在写插件时用到了 onresize 事件,在反复地测试后发现该事件在 Chrome 及 Opera(内核基本与 Chrome 相同,以下统称 Chrome)浏览器打开时就会执行,这种情况也许不能算作 ...
- MVVM设计模式和WPF中的实现(四)事件绑定
MVVM设计模式和在WPF中的实现(四) 事件绑定 系列目录: MVVM模式解析和在WPF中的实现(一)MVVM模式简介 MVVM模式解析和在WPF中的实现(二)数据绑定 MVVM模式解析和在WPF中 ...
- C++中的事件分发
本文意在展现一个C++实现的通用事件分发系统,能够灵活的处理各种事件.对于事件处理函数的注册,希望既能注册到普通函数,注册到事件处理类,也能注册到任意类的成员函数.这样在游戏客户端的逻辑处理中,可以非 ...
- 移动端IOS点击事件失效解决方案
解决方案 解决办法有 4 种可供选择: 1 将 click 事件直接绑定到目标元素(即 .target)上 2 将目标元素换成 <a> 或者 button 等可点击的元素 3 将 clic ...
- Android笔记——Button点击事件几种写法
Button点击事件:大概可以分为以下几种: 匿名内部类 定义内部类,实现OnClickListener接口 定义的构造方法 用Activity实现OnClickListener接口 指定Button ...
随机推荐
- Clojure:通过ZeroMQ推送消息
通过ZeroMQ的pub/sub模式,我们可以实现发送推送消息的功能.以下为示例代码(入门可参考此文:http://www.cnblogs.com/ilovewindy/p/3984269.html) ...
- SharePoint 2013:解决添加域名后每次都需要登录的问题
在SharePoint 2013中,当我们添加一个域名给SP后(添加域名的方法请参考此文:http://www.cnblogs.com/jianyus/archive/2013/08/10/32494 ...
- webservices系列(五)——javaweb整合Axis2及多service配置
1.新建一个项目动态web项目webservice_test3. 2.打开<Tomcat安装目录>webapps/axis2/WEB-INF.将lib.conf.modules三个目录复制 ...
- Delphi春天将来临,Android遇到XE7我也是醉了,Hello World
回首往日,从Delphi 7走到如今.总感觉不愠不火.期间论坛倒掉无数,没倒掉的也半死不活,大批的程序猿转向C#,Java,PHP. Delphi的开发高效有目共睹,一直不忍放弃.Delphi以前一夜 ...
- ubuntu消除登录痕迹
清除登陆系统成功的记录 [root@localhost root]# echo > /var/log/wtmp //此文件默认打开时乱码,可查到ip等信息 [root@localhost roo ...
- wait()方法写在while循环中可以在线程接到通知后再一次判断条件
wait()方法写在while循环中可以在线程接到通知后再一次判断条件 synchronized public String pop() { String returnValue = "&q ...
- 一个简单RPC框架是怎样炼成的(I)——开局篇
开场白,这是一个关于RPC的相关概念的普及篇系列,主要是通过一步步的调整,提炼出一个相对完整的RPC框架. RPC(Remote Procedure Call Protocol)--远程过程调用协议, ...
- 好记性不如烂笔头——.NET运行原理
WINDOWS中运行的代码,分为托管代码和非托管代码. .NET环境中运行的代码就是托管代码,.NET环境外运行的就是非托管代码. 我们开发的时候,会对源代码进行编译.但其实,对于托管代码,我们编译出 ...
- leetcode String相关
目录 3无重复字符的最长子串 5最长回文子串 8字符串转换整数(atoi), 9回文数,7整数反转 28实现strStr(), 459重复的子字符串(KMP) 43字符串相乘 71简化路径 93复原I ...
- PCB LDI文件 自动化输出(改造)实现思路
由于工厂采用Liunxs系统输出LDI文件,由于我们数据库是用的Windows Server,编程语言是.net 无法与Liunxs系统进行有效对接, 所以造成才会造成LDI 资料输效率极低,人员工作 ...