用SmartGWT的 TileGrid 来展示一系列的图片,确实很方便。
DetailViewerField picField = new DetailViewerField( "url");
picField.setType( "image");
picField.setImageHeight( tileHeight);
tileGrid.setFields( picField);
只要这样就可以显示了。
接下来的一个需求害惨我了:在每张图片上加一个空白的star,用户点击这个star,就会变成
实心的star,就像gmail里面的邮件star一样,说白了就是个favorite。
看TileGrid的代码,知道它提供了几个重载点,一个是 getTileHTML,可以自己定义tile的html。
这个当需要自己设定图片的一些tooltip来作为图片信息的时候,可以返回一个带 title的img,确实
有用。不过,对于我要增加一个带响应事件的ImgButton来说,还不够。
另一个是 getTile( int )方法。本来我是想重载 getTile(Record)方法,后来发现这个方法重载了
没用。于是在 getTile( int)里面,往super.getTile( int)的返回Canvas里面添加一个 ImgButton。
确实挺简单的,接下来的事情就很郁闷了。
图片都显示出来了,点击 star也都没问题,相应的事件也都没问题。正当要松口气的时候,发现TileGrid
换页出问题了。换了页之后,star都发生变化了,但是相应的图片没变化。顿时很震惊,不可思议。
使用N种工具,包括SmartClient自身的console,都没看出所以然来。期间走了很多弯路,最后冷静下来,
想想其实差别只是 canvas.add(btn)这行代码。将它注释掉,就正常,否则就不正常。
SmartGWT 的 console,把redraw部分的日志改成debug,发现区别不大,只是一个是:
15:01:13.986:MMV8:INFO:redraws:isc_MyRootPanel$3_0_tile_6:Scheduling redraw (1 children) (state change)
另一个是:
15:03:37.371:MMV9:INFO:redraws:isc_MyRootPanel$3_0_tile_7:Scheduling redraw (state change)
就是这个 children的区别而已。也就是说,当这个canvas 在redraw的时候,如果发现它有child,那么就直接让
child 去redraw,而canvas本身不变。就是因为这个原因,所以加上child之后,换页的时候图片不发生变化。
于是在addChild之后手工加了一个redraw,发现还是不行。马上就发现自己犯了个低级错误。既然加了child之后
在页面redraw不行,那么在代码中肯定也不行。唯一有效的,就是在addChild之前redraw一下。果然就OK了。
tile.redraw();
tile.addChild( btn);
就这么解决了。
update:
总感觉这种用法太诡异,忍不住跟踪了一下js代码,美化之后的redraw代码是这样的:
, isc.A.$ra = function isc_Canvas__updateHTML() {
var _1 = this.logIsDebugEnabled(this.$n3),
_2 = this.logIsInfoEnabled(this.$n3),
_3;
if (_1) _3 = isc.timeStamp();
if (_2) this.logInfo("$ra(): redrawing", "drawing");
if (this.peers != null && this.peers.getLength() > 0) this.redrawPredrawnPeers();
var _4 = this.children && this.children.length > 0,
_5 = this.allowContentAndChildren && _4;
if (_4 && !_5 && this.shouldRedrawOnResize()) {
_5 = true
}
if ((!_4 || _5) && (this.getVisibleWidth() > this.getWidth() || this.getVisibleHeight() > this.getHeight())) {
this.$q5(null, null, this.width, this.$o8)
}
if (_4) {
if (_5) this.$p9();
this.redrawChildren()
} else {
this.$rd()
}
if (this.$qe && !_4) {
delete this.$re;
this.enforceScrollSize(this.$qe[0], this.$qe[1])
}
this.modifyContent();
if (isc.screenReader) this.addContentRoles();
this.setUpEvents();
this.$q7 = false;
this.adjustOverflow(this.$n0, null, true);
this.redrawPeers();
if (_1) {
this.logDebug("Redraw() - Total time to redraw in DOM:" + (isc.timeStamp() - _3), "drawing")
}
return this
}
虽然加入了混淆,但是仍然能看出来,关键在于 _4 和 _5,它们都为 true的情况下,才会
在redrawChildren之前运行 $p9,也就是
isc.A.$p9=function isc_Canvas__updateParentHTML()
所以,
Canvas tile = super.getTile(recordNum);
tile.setRedrawOnResize( true);
return tile;
然后就可以了,不用redraw了。这样感觉舒服一些。
不过呢,感觉SmartGWT在深入应用方面,还是会存在问题。
分享到:
相关推荐
SmartGWT是一个强大的Java框架,用于构建富互联网应用程序(RIA)。这个官方实例是学习和理解SmartGWT功能和用法的宝贵资源,尤其适合自学者。"Showcase"通常指的是一个展示各种组件、特性和功能的集合,让我们深入...
SmartGwt是一款强大的Java库,专门用于构建富互联网应用程序(RIA,Rich Internet Applications)。它基于Google的GWT(Google Web Toolkit)框架,并扩展了其功能,提供了丰富的UI组件和更高级的客户端性能优化。...
首先,SmartGWT的核心特性之一是其丰富的组件集。这些组件包括但不限于表格、树、表单、面板、图表以及各种自定义小部件。它们都经过精心设计,具有丰富的样式和配置选项,可以轻松满足多种设计需求。例如,`...
本示例项目“基于Maven的SmartGWT项目”就是这样的一个实践,它结合了两个强大的技术:Maven作为项目管理和构建工具,以及SmartGWT作为前端UI框架。下面我们将深入探讨这两个技术以及它们如何协同工作。 首先,...
SmartGWT是一个强大的Java库,专门用于构建富互联网应用程序(RIA)。这个名为"smartgwt-1.3"的压缩包文件很可能包含了SmartGWT框架的1.3版本的源代码、库文件和其他相关资源。SmartGWT是基于Google Web Toolkit ...
SmartGWT 3.1 是一个先进的Java框架,专门用于构建富互联网应用程序(Rich Internet Applications,简称RIA)。这个最新版本提供了丰富的功能和组件,旨在帮助开发者高效地开发出交互性强、用户体验优秀的Web应用。...
SmartGWT是一个强大的Java框架,用于构建富互联网应用程序(RIA)。它基于Google Web Toolkit (GWT) 并扩展了其功能,提供了丰富的组件库和高级的UI设计工具。本教程将详细阐述如何搭建SmartGWT的开发环境,以及如何...
SmartGWT 12.0 是一款强大的Java框架,专为构建富互联网应用程序(Rich Internet Applications,RIAs)而设计。这个最新版本提供了一系列增强的功能和优化,旨在提高开发效率和用户体验。SmartGWT库的核心在于它将...
SmartGWT是一个强大的Java库,专门用于构建富互联网应用程序(RIA)。它基于Google Web Toolkit (GWT) 平台,并提供了丰富的用户界面组件和优化工具,使得开发人员能够轻松创建功能丰富的、交互性强的Web应用。GWT...
SmartGWT 2.4 是一个强大的开源框架,主要用于构建企业级的富互联网应用程序(Rich Internet Applications,简称RIA)。这个框架基于Google Web Toolkit (GWT) 并且扩展了其功能,提供了丰富的组件库和高级特性,...
《SmartGwt 原生 Desktop 深度解析》 SmartGwt 是一款基于 Java 的开源库,它为开发人员提供了丰富的组件和工具,用于构建高性能、富交互式的 Web 应用程序。在 SmartGwt 中,原生的 Desktop 功能是一个强大的特性...
在SmartGWT的学习和开发过程中,经常会遇到各种挑战和问题,比如本文提到的“分页问题GridPager”。SmartGwt是一个强大的Java库,用于构建基于Web的用户界面,它提供了丰富的组件,包括ListGrid,一个功能强大的表格...
SmartGWT 是封装了 SmartClient 的 GWT API。而 SmartClient 是一个开源的企业级 Ajax 开发框架。 Google Web Toolkit 的发布,大大降低了 Java 开发人员进行 Web 开发的门槛。然而 GWT 本身提供的控件及功能相对...
SmartGWT + Spring + Hibernate 是一个常见的企业级应用开发组合,它们各自在Web应用程序开发中扮演着重要角色。SmartGWT是基于GWT(Google Web Toolkit)的一个强大的UI库,提供丰富的用户界面组件和高性能的...
SmartGWT 是封装了 SmartClient 的 GWT API。SmartGWT 有如下特色: 丰富的控件。很多较为复杂的常用界面都被包装成简单易用的控件。比如可 编辑的树形表格、查询常用的过滤器创建器和类似 Google Calendar 的日历...
"SmartGWT"是一个强大的Java库,用于构建企业级的Web应用程序。它基于Google Web Toolkit (GWT) 并提供了一系列高级组件和功能,旨在简化开发过程,提高开发效率。SmartGWT尤其适合那些需要创建数据密集型、交互性强...
### SmartGWT 入门详解 #### 一、SmartGWT 概述 **SmartGWT** 是一款基于 **Google Web Toolkit (GWT)** 的高级Web应用开发框架,旨在简化企业级Web 2.0应用的开发过程。自从 **GWT** 发布以来,它吸引了大量的...
### SmartGWT 快速开发文档 (Quick Start Guide) 关键知识点详解 #### 一、文档概述 **SmartGWT** 是一款强大的基于 Java 的 Web 应用前端框架,它支持构建高性能的企业级应用程序。本快速开发文档为 SmartGwtEE ...
smartgwt-2.0API.CHM 2009年12月18日 ... SmartGWT 2.0发布下载了
有关于smartgwt 开发的ppt,高级开发的应用。