我正在创建一个图形,这是一个图形,绘制每天创建的文档的天数和数量。 我正在使用php来创建图像。 现在,为了获得有关查询的更多详细信息,我想让用户单击创建的图像并将其重定向到更多详细信息,这是一个表。 谁能建议我如何使用onclick事件......?
<html>
<body>
<script>
function details()
{
document.getElementById("imageform").submit();
}
</script>
<form name="imageform" id="imageform" method="get" action="resultdocument.php" >
<img border="0" src="<?php graphytry.php/img.png ?>" width="304" height="228" onclick="details()"></form>
</body>
</html>
P.S: - 图像是在同一个脚本中创建的,就在这个HTML代码的上方。
PHP代码: -
<?php
# ------- The graph values in the form of associative array
$xaxis="Jan";
$yaxis=110;
$values=array(
$xaxis => $yaxis,
);
$img_width=450;
$img_height=300;
$margins=20;
# ---- Find the size of graph by substracting the size of borders
$graph_width=$img_width - $margins * 2;
$graph_height=$img_height - $margins * 2;
$img=imagecreate($img_width,$img_height);
$bar_width=20;
$total_bars=count($values);
$gap= ($graph_width- $total_bars * $bar_width ) / ($total_bars +1);
# ------- Define Colors ----------------
$bar_color=imagecolorallocate($img,0,64,128);
$background_color=imagecolorallocate($img,240,240,255);
$border_color=imagecolorallocate($img,200,200,200);
$line_color=imagecolorallocate($img,220,220,220);
# ------ Create the border around the graph ------
imagefilledrectangle($img,1,1,$img_width-2,$img_height-2,$border_color);
imagefilledrectangle($img,$margins,$margins,$img_width-1-$margins,$img_height-1-$margins,$background_color);
# ------- Max value is required to adjust the scale -------
$max_value=max($values);
$ratio= $graph_height/$max_value;
# -------- Create scale and draw horizontal lines --------
$horizontal_lines=20;
$horizontal_gap=$graph_height/$horizontal_lines;
for($i=1;$i<=$horizontal_lines;$i++){
$y=$img_height - $margins - $horizontal_gap * $i ;
imageline($img,$margins,$y,$img_width-$margins,$y,$line_color);
//$v=intval($horizontal_gap * $i /$ratio);
//imagestring($img,0,5,$y-5,$v,$bar_color);
}
# ----------- Draw the bars here ------
for($i=0;$i<$total_bars; $i++){
# ------ Extract key and value pair from the current pointer position
list($key,$value)=each($values);
$x1= $margins + $gap + $i * ($gap+$bar_width) ;
$x2= $x1 + $bar_width;
$y1=$margins +$graph_height- intval($value * $ratio) ;
$y2=$img_height-$margins;
imagestring($img,0,$x1+3,$y1-10,$value,$bar_color);
imagestring($img,0,$x1+3,$img_height-15,$key,$bar_color);
imagefilledrectangle($img,$x1,$y1,$x2,$y2,$bar_color);
}
header("Content-type:image/png");
imagepng($img);?>
答案 0 :(得分:0)
如果您需要多次点击图片而不是单击,您可以查看创建image map
并为具有单独AJAX请求的点击事件生成x1,y1,x2,y2坐标的选项。
有关图片地图的更多信息:click here
如果您只是寻找单击,那么正如@Andreas建议的那样,请使用下面的
&lt; a href =“resultdocument.php”&gt;&lt; img /&gt;&lt; / a&gt;