GWTでタグクラウドを使用するためにtagcloud_0.4.jarを使用しています。さて、タグクラウド内のタグをクリックすると、そのイベントをどのように処理できますか、またはユーザーがクラウドからタグを選択したときにRPC呼び出しを行うにはどうすればよいですか?
ありがとう。
クラウドでClickEventをキャッチする例を次に示します。ただし、ライブラリが変更される可能性があるため、これは回避策です。開発者はクラウドでもタグでもイベントを管理することを提案していないので、これはおそらく正当な理由です...
したがって、このコードは自己責任で使用してください。ウィジェットの構造DOMが変更されないように祈ってください。そのようなイベントの管理など、ウィジェットのいくつかの機能強化を開発者に依頼することをお勧めします。
final TagCloud cloud = new TagCloud();
cloud.addWord(new WordTag("AAA"));
cloud.addWord(new WordTag("AAA"));
cloud.addWord(new WordTag("BBB"));
cloud.addWord(new WordTag("CCC"));
cloud.addWord(new WordTag("CCC"));
cloud.addWord(new WordTag("CCC"));
cloud.addDomHandler(new ClickHandler() {
@Override
public void onClick(ClickEvent event) {
// Prevent the click from the tag to be executed
event.preventDefault();
Element e;
// For each tag present in the cloud, look for the one that is triggered
for (int i = 0; i < cloud.getTags().size(); ++i) {
// Gets the element in the cloud, this really is the unsafe part of the code
// if the developer change the dom of its widget
e = DOM.getChild(DOM.getChild(cloud.getElement(), 0), i);
// Is the current element targeted by the event?
if (event.getClientX() >= e.getOffsetLeft() && event.getClientY() >= e.getOffsetTop()
&& event.getClientX() <= e.getOffsetLeft() + e.getOffsetWidth()
&& event.getClientY() <= e.getOffsetTop() + e.getOffsetHeight()) {
// Gets the abstract tag
Tag t = cloud.getTags().get(i);
// Gets tag descendant
if (t instanceof WordTag) {
// Do what you want with your WordTag, maybe an RPC call
} else if (t instanceof ImageTag) {
// Do what you want with your ImageTag, maybe an RPC call
}
break;
}
}
}
}, ClickEvent.getType());