2013-05-07 35 views
0

我正在創建一個圖形,這是一張圖表,繪製了每天創建的文檔的日期和時間。 我使用PHP來創建圖像。 現在,要獲取有關查詢的更多詳細信息,我想讓用戶單擊所創建的圖像並將其重定向到更多詳細信息,即表格。 任何人都可以建議我如何使用onclick事件...?如何在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

你也可以發佈你的PHP代碼嗎? – NullPointer 2013-05-07 09:46:29

+3

這裏不需要'onclick'。只需用超鏈接替換表單,然後完成'' – Andreas 2013-05-07 09:48:50

+0

它有點長,我會嘗試發佈它。 – Ameya 2013-05-07 09:50:11

回答

0

你可以看一下創建image map的選項,併產生X1,Y1,X2,Y2座標與單獨的AJAX請求,請點擊事件,如果你需要有多次點擊圖片而不是單擊。

更多圖像映射:click here

如果你只是尋找單一的點擊,那麼作爲@Andreas建議,請使用以下

< A HREF = 「resultdocument.php」 > < IMG/> </a >

+0

Minesh您從w3schools.com分享的示例。看着它。 是否可以使用「Click for More details」作爲下一個php頁面的標籤? – Ameya 2013-05-07 10:03:41

+0

@Ameya,是的,爲什麼不呢,你可以在地圖區域標籤的href屬性中指定下一頁的URL。 – Minesh 2013-05-07 10:10:22

相關問題