亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? jpgraph_radar.php

?? asterisk用 的voip記費軟件
?? PHP
?? 第 1 頁 / 共 2 頁
字號:
<?php/*=======================================================================// File:	JPGRAPH_RADAR.PHP// Description: Radar plot extension for JpGraph// Created: 	2001-02-04// Author:	Johan Persson (johanp@aditus.nu)// Ver:		$Id: jpgraph_radar.php,v 1.7.2.5 2004/06/12 17:46:01 aditus Exp $//// License:	This code is released under QPL// Copyright (C) 2001,2002 Johan Persson//========================================================================*/require_once('jpgraph_plotmark.inc');class RadarLogTicks extends Ticks {//---------------// CONSTRUCTOR    function RadarLogTicks() {    }//---------------// PUBLIC METHODS	    // TODO: Add Argument grid    function Stroke(&$aImg,&$grid,$aPos,$aAxisAngle,&$aScale,&$aMajPos,&$aMajLabel) {	$start = $aScale->GetMinVal();	$limit = $aScale->GetMaxVal();	$nextMajor = 10*$start;	$step = $nextMajor / 10.0;	$count=1; 					$ticklen_maj=5;	$dx_maj=round(sin($aAxisAngle)*$ticklen_maj);	$dy_maj=round(cos($aAxisAngle)*$ticklen_maj);	$ticklen_min=3;	$dx_min=round(sin($aAxisAngle)*$ticklen_min);	$dy_min=round(cos($aAxisAngle)*$ticklen_min);				$aMajPos=array();	$aMajLabel=array();				if( $this->supress_first )	    $aMajLabel[]="";	else	    $aMajLabel[]=$start;		$yr=$aScale->RelTranslate($start);		$xt=round($yr*cos($aAxisAngle))+$aScale->scale_abs[0];	$yt=$aPos-round($yr*sin($aAxisAngle));	$aMajPos[]=$xt+2*$dx_maj;	$aMajPos[]=$yt-$aImg->GetFontheight()/2;	$grid[]=$xt;	$grid[]=$yt;	$aImg->SetLineWeight($this->weight);						for($y=$start; $y<=$limit; $y+=$step,++$count  ) {	    $yr=$aScale->RelTranslate($y);		    $xt=round($yr*cos($aAxisAngle))+$aScale->scale_abs[0];	    $yt=$aPos-round($yr*sin($aAxisAngle));	    if( $count % 10 == 0 ) {		$grid[]=$xt;		$grid[]=$yt;		$aMajPos[]=$xt+2*$dx_maj;		$aMajPos[]=$yt-$aImg->GetFontheight()/2;									if( !$this->supress_tickmarks )	{				    if( $this->majcolor!="" ) $aImg->PushColor($this->majcolor);		    $aImg->Line($xt+$dx_maj,$yt+$dy_maj,$xt-$dx_maj,$yt-$dy_maj);		    if( $this->majcolor!="" ) $aImg->PopColor();		}		$aMajLabel[]=$nextMajor;			$nextMajor *= 10;		$step *= 10;			$count=1; 					    }	    else		if( !$this->supress_minor_tickmarks )	{		    if( $this->mincolor!="" ) $aImg->PushColor($this->mincolor);		    $aImg->Line($xt+$dx_min,$yt+$dy_min,$xt-$dx_min,$yt-$dy_min);		    if( $this->mincolor!="" ) $aImg->PopColor();		}	}		    }		}	class RadarLinearTicks extends LinearTicks {//---------------// CONSTRUCTOR    function RadarLinearTicks() {	// Empty    }//---------------// PUBLIC METHODS	    // TODO: Add argument grid    function Stroke(&$aImg,&$grid,$aPos,$aAxisAngle,&$aScale,&$aMajPos,&$aMajLabel) {	// Prepare to draw linear ticks	$maj_step_abs = abs($aScale->scale_factor*$this->major_step);		$min_step_abs = abs($aScale->scale_factor*$this->minor_step);		$nbrmaj = floor(($aScale->world_abs_size)/$maj_step_abs);	$nbrmin = floor(($aScale->world_abs_size)/$min_step_abs);	$skip = round($nbrmin/$nbrmaj); // Don't draw minor ontop of major	// Draw major ticks	$ticklen2=$this->major_abs_size;	$dx=round(sin($aAxisAngle)*$ticklen2);	$dy=round(cos($aAxisAngle)*$ticklen2);	$label=$aScale->scale[0]+$this->major_step;			$aImg->SetLineWeight($this->weight);			for($i=1; $i<=$nbrmaj; ++$i) {	    $xt=round($i*$maj_step_abs*cos($aAxisAngle))+$aScale->scale_abs[0];	    $yt=$aPos-round($i*$maj_step_abs*sin($aAxisAngle));	    $aMajLabel[]=$label;	    $label += $this->major_step;	    $grid[]=$xt;	    $grid[]=$yt;	    $aMajPos[($i-1)*2]=$xt+2*$dx;	    $aMajPos[($i-1)*2+1]=$yt-$aImg->GetFontheight()/2;					    if( !$this->supress_tickmarks ) {		if( $this->majcolor!="" ) $aImg->PushColor($this->majcolor);		$aImg->Line($xt+$dx,$yt+$dy,$xt-$dx,$yt-$dy);		if( $this->majcolor!="" ) $aImg->PopColor();	    }	}	// Draw minor ticks	$ticklen2=$this->minor_abs_size;	$dx=round(sin($aAxisAngle)*$ticklen2);	$dy=round(cos($aAxisAngle)*$ticklen2);	if( !$this->supress_tickmarks && !$this->supress_minor_tickmarks)	{	    if( $this->mincolor!="" ) $aImg->PushColor($this->mincolor);							    for($i=1; $i<=$nbrmin; ++$i) {		if( ($i % $skip) == 0 ) continue;		$xt=round($i*$min_step_abs*cos($aAxisAngle))+$aScale->scale_abs[0];		$yt=$aPos-round($i*$min_step_abs*sin($aAxisAngle));		$aImg->Line($xt+$dx,$yt+$dy,$xt-$dx,$yt-$dy);	    }	    if( $this->mincolor!="" ) $aImg->PopColor();	}    }}	//===================================================// CLASS RadarAxis// Description: Implements axis for the spider graph//===================================================class RadarAxis extends Axis {    var $title_color="navy";    var $title=null;//---------------// CONSTRUCTOR    function RadarAxis(&$img,&$aScale,$color=array(0,0,0)) {	parent::Axis($img,$aScale,$color);	$this->len=$img->plotheight;	$this->title = new Text();	$this->title->SetFont(FF_FONT1,FS_BOLD);	$this->color = array(0,0,0);    }//---------------// PUBLIC METHODS	    function SetTickLabels($l) {	$this->ticks_label = $l;    }		    // Stroke the axis     // $pos 			= Vertical position of axis    // $aAxisAngle = Axis angle    // $grid			= Returns an array with positions used to draw the grid    //	$lf			= Label flag, TRUE if the axis should have labels    function Stroke($pos,$aAxisAngle,&$grid,$title,$lf) {	$this->img->SetColor($this->color);			// Determine end points for the axis	$x=round($this->scale->world_abs_size*cos($aAxisAngle)+$this->scale->scale_abs[0]);	$y=round($pos-$this->scale->world_abs_size*sin($aAxisAngle));			// Draw axis	$this->img->SetColor($this->color);	$this->img->SetLineWeight($this->weight);	if( !$this->hide )	    $this->img->Line($this->scale->scale_abs[0],$pos,$x,$y);		$this->scale->ticks->Stroke($this->img,$grid,$pos,$aAxisAngle,$this->scale,$majpos,$majlabel);			// Draw labels	if( $lf && !$this->hide ) {	    $this->img->SetFont($this->font_family,$this->font_style,$this->font_size);		    $this->img->SetTextAlign("left","top");	    $this->img->SetColor($this->color);				    // majpos contsins (x,y) coordinates for labels	    for($i=0; $i<count($majpos)/2; ++$i) {		if( $this->ticks_label != null )		    $this->img->StrokeText($majpos[$i*2],$majpos[$i*2+1],$this->ticks_label[$i]);		else		    $this->img->StrokeText($majpos[$i*2],$majpos[$i*2+1],$majlabel[$i]);	    }	}	$this->_StrokeAxisTitle($pos,$aAxisAngle,$title);    }//---------------// PRIVATE METHODS		    function _StrokeAxisTitle($pos,$aAxisAngle,$title) {	$this->title->Set($title);	$marg=6+$this->title->margin;	$xt=round(($this->scale->world_abs_size+$marg)*cos($aAxisAngle)+$this->scale->scale_abs[0]);	$yt=round($pos-($this->scale->world_abs_size+$marg)*sin($aAxisAngle));	// Position the axis title. 	// dx, dy is the offset from the top left corner of the bounding box that sorrounds the text	// that intersects with the extension of the corresponding axis. The code looks a little	// bit messy but this is really the only way of having a reasonable position of the	// axis titles.	$h=$this->img->GetFontHeight();	$w=$this->img->GetTextWidth($title);	while( $aAxisAngle > 2*M_PI ) $aAxisAngle -= 2*M_PI;	if( $aAxisAngle>=7*M_PI/4 || $aAxisAngle <= M_PI/4 ) $dx=0;	if( $aAxisAngle>=M_PI/4 && $aAxisAngle <= 3*M_PI/4 ) $dx=($aAxisAngle-M_PI/4)*2/M_PI; 	if( $aAxisAngle>=3*M_PI/4 && $aAxisAngle <= 5*M_PI/4 ) $dx=1;	if( $aAxisAngle>=5*M_PI/4 && $aAxisAngle <= 7*M_PI/4 ) $dx=(1-($aAxisAngle-M_PI*5/4)*2/M_PI);			if( $aAxisAngle>=7*M_PI/4 ) $dy=(($aAxisAngle-M_PI)-3*M_PI/4)*2/M_PI;	if( $aAxisAngle<=M_PI/4 ) $dy=(1-$aAxisAngle*2/M_PI);	if( $aAxisAngle>=M_PI/4 && $aAxisAngle <= 3*M_PI/4 ) $dy=1;	if( $aAxisAngle>=3*M_PI/4 && $aAxisAngle <= 5*M_PI/4 ) $dy=(1-($aAxisAngle-3*M_PI/4)*2/M_PI);	if( $aAxisAngle>=5*M_PI/4 && $aAxisAngle <= 7*M_PI/4 ) $dy=0;			if( !$this->hide ) {	    $this->title->Stroke($this->img,$xt-$dx*$w,$yt-$dy*$h,$title);	}    }			} // Class//===================================================// CLASS RadarGrid// Description: Draws grid for the spider graph//===================================================class RadarGrid extends Grid {//------------// CONSTRUCTOR    function RadarGrid() {    }//----------------// PRIVATE METHODS	    function Stroke(&$img,&$grid) {	if( !$this->show ) return;	$nbrticks = count($grid[0])/2;	$nbrpnts = count($grid);	$img->SetColor($this->grid_color);	$img->SetLineWeight($this->weight);	for($i=0; $i<$nbrticks; ++$i) {	    for($j=0; $j<$nbrpnts; ++$j) {		$pnts[$j*2]=$grid[$j][$i*2];		$pnts[$j*2+1]=$grid[$j][$i*2+1];	    }	    for($k=0; $k<$nbrpnts; ++$k ){		$l=($k+1)%$nbrpnts;		if( $this->type == "solid" )		    $img->Line($pnts[$k*2],$pnts[$k*2+1],$pnts[$l*2],$pnts[$l*2+1]);		elseif( $this->type == "dotted" )		    $img->DashedLine($pnts[$k*2],$pnts[$k*2+1],$pnts[$l*2],$pnts[$l*2+1],1,6);		elseif( $this->type == "dashed" )		    $img->DashedLine($pnts[$k*2],$pnts[$k*2+1],$pnts[$l*2],$pnts[$l*2+1],2,4);		elseif( $this->type == "longdashed" )		    $img->DashedLine($pnts[$k*2],$pnts[$k*2+1],$pnts[$l*2],$pnts[$l*2+1],8,6);	    }	    $pnts=array();	}    }} // Class//===================================================// CLASS RadarPlot// Description: Plot a spiderplot//===================================================class RadarPlot {    var $data=array();    var $fill=false, $fill_color=array(200,170,180);    var $color=array(0,0,0);    var $legend="";    var $weight=1;    var $linestyle='solid';    var $mark=null;//---------------// CONSTRUCTOR    function RadarPlot($data) {	$this->data = $data;	$this->mark = new PlotMark();    }//---------------// PUBLIC METHODS	    function Min() {	return Min($this->data);    }	    function Max() {	return Max($this->data);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩一区二区三区在线| 自拍偷自拍亚洲精品播放| 久久精品亚洲精品国产欧美| 国产精品蜜臀在线观看| 夜夜揉揉日日人人青青一国产精品| 亚洲va国产天堂va久久en| 国产精品亚洲一区二区三区在线| 色婷婷av一区二区| 日本一区二区动态图| 三级久久三级久久久| 91免费小视频| 国产精品国产自产拍在线| 老鸭窝一区二区久久精品| 欧美亚洲精品一区| 中文字幕在线不卡| 国产成人午夜视频| 久久中文字幕电影| 久久精品国产秦先生| 91精品久久久久久久91蜜桃 | 极品少妇一区二区三区精品视频| av成人免费在线| 国产拍欧美日韩视频二区| 日本成人在线看| 69堂国产成人免费视频| 亚洲一区二区不卡免费| 色噜噜狠狠成人中文综合 | 日韩精品一区二区三区三区免费| 亚洲欧美日本韩国| 91女人视频在线观看| 中文字幕一区二| 91在线精品秘密一区二区| 久久精品亚洲精品国产欧美kt∨ | 亚洲国产另类av| 91麻豆免费观看| 日韩理论片网站| 91在线看国产| 亚洲午夜电影在线| 欧美日韩日本视频| 日本强好片久久久久久aaa| 欧美日韩精品久久久| 亚洲v中文字幕| 欧美日韩一卡二卡三卡 | 国产成人av电影在线观看| 26uuu久久天堂性欧美| 久久97超碰国产精品超碰| 日韩欧美国产不卡| 国产精品77777竹菊影视小说| 久久伊99综合婷婷久久伊| 国产成人午夜电影网| 亚洲高清免费在线| 91精品国产一区二区三区蜜臀| 五月天激情综合| 欧美三级电影网| 日韩高清一区二区| 337p粉嫩大胆色噜噜噜噜亚洲 | 色老综合老女人久久久| 亚洲成人福利片| 精品国产3级a| eeuss鲁片一区二区三区在线看| 国产精品乱码一区二区三区软件| 色综合欧美在线| 午夜精品爽啪视频| 欧美极品aⅴ影院| 日本高清视频一区二区| 蜜桃视频在线一区| 欧美激情综合五月色丁香| 91免费版在线看| 美女视频一区在线观看| 国产视频不卡一区| 欧美日本韩国一区二区三区视频| 激情久久五月天| 中文字幕在线不卡| 欧美电影免费观看高清完整版| 成人美女在线观看| 日韩高清在线观看| 国产精品视频你懂的| 538在线一区二区精品国产| 国产91精品一区二区麻豆亚洲| 一区二区欧美视频| 欧美激情艳妇裸体舞| 欧美性色欧美a在线播放| 国产一区二区三区美女| 亚洲午夜久久久久中文字幕久| 久久色中文字幕| 欧美高清一级片在线| 成人在线综合网| 久久国产精品区| 亚洲五码中文字幕| 综合久久综合久久| 久久综合国产精品| 欧美不卡一区二区| 欧美女孩性生活视频| 日本道在线观看一区二区| 国产精品18久久久久| 日韩在线一区二区三区| 一区二区三区在线免费视频| 国产欧美日韩麻豆91| 日韩精品中文字幕一区| 欧美日韩在线播放| 在线视频你懂得一区| av毛片久久久久**hd| 国产精品99久久不卡二区| 国产在线视频一区二区| 日韩电影网1区2区| 亚洲一区二区三区四区中文字幕| 中文字幕欧美国产| 久久久噜噜噜久久人人看 | 欧美精品免费视频| 在线视频欧美精品| 欧美在线观看禁18| 在线影视一区二区三区| 一本一道波多野结衣一区二区 | 国产毛片精品视频| 国产一区二区影院| 国产精品888| 成人午夜电影久久影院| 国产成人精品一区二区三区四区| 精品综合久久久久久8888| 日韩电影在线观看网站| 美日韩黄色大片| 久久国产三级精品| 制服丝袜日韩国产| 久久―日本道色综合久久| 精品国产乱码久久久久久蜜臀| 国产在线精品不卡| 亚洲综合成人在线| 亚洲成人资源在线| 日本一区中文字幕| 美国十次综合导航| 国产精品一级片在线观看| 国产精品影音先锋| 成人国产精品视频| 色综合久久六月婷婷中文字幕| 色av成人天堂桃色av| 欧美日韩国产美女| 精品福利一区二区三区免费视频| 精品剧情在线观看| 国产精品国产三级国产有无不卡| 亚洲色图在线播放| 午夜精品免费在线| 国产一区中文字幕| 色综合久久天天| 欧美va亚洲va香蕉在线| 国产精品久久久久7777按摩 | 岛国一区二区三区| 色狠狠色狠狠综合| 日韩欧美一二区| 国产精品嫩草影院av蜜臀| 亚洲国产一区二区三区 | 亚洲国产精品成人综合色在线婷婷 | 成人美女视频在线看| 欧美丝袜丝nylons| 精品免费日韩av| 亚洲视频在线一区观看| 日本成人在线一区| 成人avav影音| 日韩一二三四区| 中文字幕不卡的av| 青青草国产精品亚洲专区无| 成人国产在线观看| 欧美精品久久久久久久多人混战 | 26uuu亚洲综合色欧美| 亚洲综合自拍偷拍| 国产成人综合在线播放| 在线观看欧美黄色| 国产午夜精品一区二区三区四区| 亚洲综合色在线| 国产999精品久久| 91精品国产综合久久久久久漫画| 国产精品毛片高清在线完整版| 日韩电影在线免费| 欧美日韩一区三区| 亚洲欧洲精品成人久久奇米网| 久久福利资源站| 欧美日韩亚洲高清一区二区| 国产精品白丝在线| 国产在线一区二区| 欧美日韩黄色影视| 91国产精品成人| 亚洲激情自拍偷拍| 欧美麻豆精品久久久久久| 中文字幕一区二区三区乱码在线 | 国产一区二区女| 日韩你懂的在线观看| 午夜精品一区二区三区电影天堂| 成人一区在线观看| 国产日产欧产精品推荐色| 青椒成人免费视频| 337p亚洲精品色噜噜| 性做久久久久久久免费看| 色综合天天做天天爱| 中文字幕在线观看不卡视频| 国产二区国产一区在线观看 | 欧美精品电影在线播放| 亚洲黄色小视频| 欧洲日韩一区二区三区| 亚洲女同ⅹxx女同tv| 一本久久a久久精品亚洲| 亚洲女与黑人做爰| 欧美日本在线视频|