當用戶單擊圖像時,我嘗試了將鼠標座標放入後臺bean的各種方法。我可以在javascript中獲取座標,然後調用ajax監聽器,但參數不在請求中。如何在點擊圖像時將鼠標座標傳遞給後臺bean
我的JS:
if (!cis) var cis = {}
if (!cis.sarwinds) {
var focusLostTimeout
cis.sarwinds = {
errorHandler: function(data) {
alert("Error occurred during Ajax call: " + data.description)
},
updateZoomValues: function(input, event) {
jsf.ajax.addOnError(cis.sarwinds.errorHandler)
var offset = jQuery(input).offset();
jsf.ajax.request(input, event, {
render: "imagePan2 message",
x: event.pageX - offset.left,
y: event.pageY - offset.top
})
},
getGraphicImageId: function(input) {
var clientId = new String(input.name)
var lastIndex = clientId.lastIndexOf(":")
return clientId.substring(0, lastIndex) + ":imagePan2"
}
}
}
我的JSF頁面元素:
<h:graphicImage id="imagePan2" library="images" styleClass="wind_map" name="testImage.jpg" style="#{SarWindsImagesBean.imageStyle('testImage.jpg')}">
<f:ajax event="click" onevent="cis.sarwinds.updateZoomValues(this, event)" listener="#{SarWindsImagesBean.zoomInClick}" render="imagePan2 message"/>
</h:graphicImage>
我支持bean:
public void zoomInClick(AjaxBehaviorEvent event) {
double width;
double height;
double top;
double left;
double mouseX;
double mouseY;
String fileName = "testImage";
Map<String, String> reqParams = FacesContext.getCurrentInstance().getExternalContext().getRequestParameterMap();
mouseX = Double.parseDouble(reqParams.get("x"));
mouseY = Double.parseDouble(reqParams.get("y"));
width = imageItems.get(fileName).getImageWidth() * 1.1;
height = imageItems.get(fileName).getImageHeight() * 1.1;
// We need the mouse position on the image here, and we need to calculate
top = mouseY - ((mouseY - imageItems.get(fileName).getImageTop()) * 1.1);
left = mouseX - ((mouseX - imageItems.get(fileName).getImageLeft()) * 1.1);
if (this.imageLock == false){
imageItems.put(fileName, new SarWindImageItem(width, height, top, left));
} else {
Iterator<String> it = imageItems.keySet().iterator();
while (it.hasNext()) {
String key = (String)it.next();
imageItems.put(key, new SarWindImageItem(width, height, top, left));
}
}
}
的reqParams是空的。
丹
我剛剛嘗試過,但不斷收到「serverError:org.apache.myfaces.view.facelets.el.ContextAwareELException javax.el.ELException:java.lang.NullPointerException 請注意,此消息僅發送,因爲項目階段是發展和沒有其他錯誤聽衆註冊。「 – Danpoleary
啊,MyFaces ...用'Integer'替換int。我更新了答案。順便提一下,這暗示着隱藏的輸入根本沒有設置。你是否拷貝了確切的代碼或者修改了一些? – BalusC
我想我找到了我的問題。我修改它以適應會話支持bean邏輯,我已經將圖像圖層綁定到相同的座標點擊。我正在嘗試它,並會發布我的結果。感謝您的反饋。 – Danpoleary