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

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

?? axis.class

?? 是一個經濟學管理應用軟件 很難找的 但是經濟學學生又必須用到
?? CLASS
?? 第 1 頁 / 共 2 頁
字號:
/*                                  axis

	Class for axis views.

    Note, the max and min for ticksets must be set through the _set_xyz_min
	  programs provided here.
*/

*! version 1.0.8  19jul2004
version 8

class {
	style		= .axisstyle.new
	position	= .relative_posn.new

	title		= .sized_textbox.new

	.major		= .tickset_g.new		// labeled major ticks
	.minor		= .tickset_g.new		// labeled minor ticks
	.majornl	= .tickset_g.new		// unlabeled major ticks
	.minornl	= .tickset_g.new		// unlabeled minor ticks

	draw_view       = .yesno.new, style(yes)	// ok, primitive style
	fill_if_undrawn = .yesno.new, style(no)
	force_draw	= .yesno.new, style(yes)	// for grid

	// plotregion -- declared dynmaically by reference

	xtransform = .transform.new , dimension(x)	// so axis can act
	ytransform = .transform.new , dimension(y)	// as container 

	box_alignment	= .compass2dir.new , style(center) // for aspect()

	_recreate	= .yesno.new, style(no)
	_uncreate	= .yesno.new, style(no)
	_created	= .yesno.new, style(no)

}, inherit(view)


// ----------------------------------------------------------------------------
//
//	Usage:  .new , plotregion(plotregion) [ position(left|right|below|above)
//			label_position style(axis_stylename) 
//			titlestyle(textbox_stylename) title(title_text) ]

program define new
				// apply default style settings if they are
				// not about to be reset by options
	syntax [ , Style(string) TITLEStyle(string) * ]
	if "`titlestyle'" == "" { 
		.title.set, style(scheme axis_title)
	}
	if "`style'" == ""      { 
		.style.setstyle, style(scheme)
	}

	.set `0'
	.set_formats
	.set_scales

	.minor.Declare mymajor   = .major.ref
	.minornl.Declare mymajor = .major.ref

	.set_ticks
end

program define set

	syntax [, PLotregion(string) POSition(string) Style(passthru) 	///
		  LAbel_position TITLE(string asis) TITLEStyle(string) * ]

	if `"`title'"' != `""' { 
		local title text(`title') 
	}
	if "`titlestyle'" != "" { 
		local titlestyle `"style(`titlestyle')"'
	}

	if "`plotregion'" != "" {
		if "`.Local.plotregion.isa'" == "" {
			.Declare plotregion = .Global.`plotregion'.ref
		}
		else	.plotregion.ref = .Global.`plotregion'.ref

		local ord = cond("`position'"=="left" |			///
				 "`position'"=="right", "y", "x")
		.`plotregion'.`ord'scale.add_axis `.objkey'
		.`plotregion'.addaxis `.objkey'
	}

	if "`style'" != "" { 
		.style.setstyle, `style'
	}

	.Super.set , `options'

	if "`position'" != "" {
		.position.setstyle, style(`position')

		if "`position'" == "left" | "`position'" == "right" {
			.xstretch.set fixed
			.ystretch.set shared
		}
		else if "`position'" == "below" | "`position'" == "above" {
			.xstretch.set shared
			.ystretch.set fixed
		}
	}

	if "`.position.snm'" == "left" | "`.position.snm'" == "right" {
		local orient orientation(vertical)
	}
	.title.edit, `title' `titlestyle' `orient'

end

// ---------------------------------------------------------------------------
//  Lets each of the ticksets use natscale to select a range and actual number
//  of ticks, then sets the scale to be the smallest miniumum and largest
//  maximum.

program define set_ticks
	args only_default

	if ! 0`.plotregion.isofclass plotregion' {
		exit					// no plotregion
	}

	local ord = cond("`.position.snm'"=="left" |			///
			 "`.position.snm'"=="right", "y", "x") 

	local min = 0`.plotregion.`ord'scale.min'
	local max = 0`.plotregion.`ord'scale.max'

	if `min' > `max' {					// not set yet
		exit 
	}			

	foreach ticks in major majornl minor {
		.`ticks'.set_ticks `min' `max'				///
			`.style.`ticks'style.numticks.val' `only_default'
	}
	.reset_scale 
        .minornl.suggest_between_ticks `.style.minornlstyle.numticks.val'
end


program define _set_ticks
	set_ticks `0'
end

program define reset_scale

	local ord = cond("`.position.snm'"=="left" |			///
			 "`.position.snm'"=="right", "y", "x") 
	.plotregion.`ord'scale.reset_from_axes
end


// ---------------------------------------------------------------------------
// Return the overall min/max of all the ticksets of the axis.

program overallmin
	local omin 1e300
	foreach ticks in major majornl minor minornl {
		local omin = min(`omin', `.`ticks'.overallmin')
	}

	class exit = `omin'
end

program define overallmax
	local omax -1e300
	foreach ticks in major majornl minor minornl {
		local omax = max(`omax', `.`ticks'.overallmax')
	}

	class exit = `omax'
end


// ---------------------------------------------------------------------------
//  Sets the formatting of each tickset to be the format picked up by the
//  plotregion.

program define set_formats
	local ord = cond("`.position.snm'"=="left" |			///
			 "`.position.snm'"=="right", "y", "x") 

	local fmt `.plotregion.dimformat `ord''

	if "`fmt'" == "" & "`.plotregion.`ord'scale._format'" != "" {
		local fmt `"`.plotregion.`ord'scale._format'"'
	}

	if "`fmt'" != "" {
		foreach ticks in major majornl minor minornl {
		      .`ticks'.set_format `fmt'
		}
	}
end


// ---------------------------------------------------------------------------
//  Let the ticksets know about their scale.

program define set_scales


	local ord = cond("`.position.snm'"=="left" | 			///
			 "`.position.snm'"=="right", "y", "x") 

	if 0`.plotregion.`ord'scale.isofclass scale' {
		foreach ticks in major majornl minor minornl {
		      .`ticks'.set_scale `.plotregion.`ord'scale.objkey'
		}
	}
end


// ---------------------------------------------------------------------------
//  Let the ticksets know about transform (log or linear).
//  They assume the current transform in the scale.

program define set_transform

	local ord = cond("`.position.snm'"=="left" | 			///
			 "`.position.snm'"=="right", "y", "x") 

	foreach ticks in major majornl minor minornl {
	      .`ticks'.set_transform `.plotregion.`ord'scale.objkey'
	}
end


// ---------------------------------------------------------------------------
//  Sets the plotregion for the axis and registers the axis with the 
//  plotregion and scale.

program set_plotregion
	args plotregion xy

	if "`plotregion'" == "" {
		exit
	}
	if "`xy'" != "x" & "`xy'" != "y" {
		exit
	}

	if "`.Local.plotregion.isa'" == "" {
		.Declare plotregion = .Global.`plotregion'.ref
	}
	else	.plotregion.ref = .Global.`plotregion'.ref

	.`plotregion'.`xy'scale.add_axis `.objkey'
	.`plotregion'.addaxis `.objkey'
end


// ---------------------------------------------------------------------------
program define xsize

	if "`.position.snm'"=="left" | "`.position.snm'"=="right" {
		local size = `.xsize_notitle' + `.style.outer_space.gmval'
		if 0`.title.draw_view.istrue' {
			local size = `size' + `.title.extent x' +	///
				     `.style.title_gap.gmval'
		}
	}
	else {
		local size cond("`.xstretch.setting'" == "fixed" ,	///
				0`.plotregion.xsize' , 0)
	}

	class exit = `size'
end

program define ysize

	if ! ( "`.position.snm'"=="left" | "`.position.snm'"=="right" ) {
		local size = `.ysize_notitle' + `.style.outer_space.gmval'
		if 0`.title.draw_view.istrue' {
			local size = `size' + `.title.extent y' + 	///
				     `.style.title_gap.gmval'
		}
	}
	else {
		local size cond("`.ystretch.setting'" == "fixed" ,	///
				0`.plotregion.ysize' , 0)
	}

	class exit = `size'
end

program define xsize_notitle

	if "`.position.snm'"!="left" & "`.position.snm'"!="right" {
		class exit = 0
	}

	class exit `._tick_and_label_width x'
end

program define ysize_notitle

	if "`.position.snm'"=="left" | "`.position.snm'"=="right" {
		class exit = 0
	}

	class exit = `._tick_and_label_width y'
end

program _tick_and_label_width
	args ord

	local frd = cond("`ord'" == "x" , "y" , "x")
	
	local max 0
	foreach ticks in major majornl minor minornl {
	    local max = max(`max', `.`ticks'._tick_and_label_width 	///
	      `.style.`ticks'style.objkey' `ord' `._value_label_series `frd''')
	}

	class exit = `max'
end

// ---------------------------------------------------------------------------
program set_userules
	args yesno

	foreach ticks in major majornl minor minornl {
		.`ticks'.use_rule.setstyle , style(`yesno')
	}
end


// ---------------------------------------------------------------------------
program clear_ticks
	foreach ticks in major majornl minor minornl {
		.`ticks'.clear_ticks
	}
end

// ---------------------------------------------------------------------------
//  Use compass_draw to allow alignment of the sized axis in an area that
//  is possibly larger than the size of the axis.

program draw

	syntax [, PLOTREgion(string) * ]

	if ("`plotregion'" == "") local plotregion plotregion


	if "`.`.position.parallel_dim'stretch.setting'" == "fixed" {
		.compass_draw , align(box_alignment)			///
			drawpgm(_sized_draw)				///
			margins(`plotregion'.style.margin)		///
			plotregion(`plotregion') `options'
	}
	else {
		.real_draw , `options'
	}
end

program _sized_draw

	syntax [, XSize(real 0) YSize(real 0) * ]

	.xsize_ren = `xsize'
	.ysize_ren = `ysize'

	.real_draw , xsize(`.xsize_ren') ysize(`.ysize_ren') `options'
end


// ---------------------------------------------------------------------------
// Note that .draw_view.isfalse implies we are only drawing the grids.
// Unless, .force_draw is also false

program define real_draw

	syntax [, XSize(real -1) YSize(real -1) GRIDONLY PLOTREgion(string) ]

	if `xsize' == -1 {
		.xsize_ren = `.xsize'
	}
	else	.xsize_ren = `xsize'

	if `ysize' == -1 {
		.ysize_ren = `.ysize'
	}
	else	.ysize_ren = `ysize'


	local gridonly = "`gridonly'" != ""

	if "`plotregion'" == "" {
		local plotregion plotregion
	}

	if ! (`.draw_view.istrue' | `gridonly') {
		exit						// Exit
	}

	.xtransform.get_from_gdi		// fetch current transform
	.ytransform.get_from_gdi


	.style.linestyle.setgdifull			// compute positions
	local pos `.position.snm'
	if "`pos'" == "default" { 
		local pos below 
	}

	if "`pos'" == "below" | "`pos'" == "above" {
	    local x0 = !`.style.extend_full_low.istrue' * 		  ///
			`.`plotregion'.style.margin.gmleft'
	    local x1 = `.xsize_ren' - !`.style.extend_full_high.istrue' * ///
			`.`plotregion'.style.margin.gmright'
	    local xtitle 0
	    local xtitlesz `.xsize_ren'
	    local ytitlesz `.title.extent y'
	    if "`pos'" == "below" {
	    	local y0 `.ysize_ren'
	    	local y1 `.ysize_ren'
		local ytitle `.style.outer_space.gmval'
	    }
	    else {
	    	local y0 0
	    	local y1 0
		local ytitle = `.ysize_notitle' + `.style.title_gap.gmval'
	    }
	}
	else if "`pos'" == "left" | "`pos'" == "right" {
	    local y0 = !`.style.extend_full_low.istrue' * 		  ///
			`.`plotregion'.style.margin.gmbottom'
	    local y1 = `.ysize_ren' - !`.style.extend_full_high.istrue' * ///
			`.`plotregion'.style.margin.gmtop'
	    local ytitle = 0
	    local xtitlesz `.title.extent x'
	    local ytitlesz `.ysize_ren'
	    if "`pos'" == "left" {
	    	local x0 = `.xsize_ren'
	    	local x1 = `.xsize_ren'
		local xtitle = `.style.outer_space.gmval'
	    }
	    else {
	    	local x0 0
	    	local x1 0
		local xtitle = `.xsize_notitle' + `.style.title_gap.gmval'
	    }
	}

							// draw main line
	if "`.style.linestyle.color.snm'" != "none" & 0`.draw_view.istrue' & ///
	   ! `gridonly' {
	    if `.style.extend' {
		gdi line `x0' `y0' `x1' `y1'	
		`crt' ._declare_array axis_line1
		`crt' .Declare axis_line1 = .line_g.new `x0' `y0' `x1' `y1', ///
			styleref(`.style.linestyle.objkey')
	    }
	    else {
		if "`pos'" == "left" | "`pos'" == "right" { 
			gdi line `x0' `.`plotregion'.yscale.curmin' 	///
				 `x1' `.`plotregion'.yscale.curmax' 
		}
		else {
			gdi line `.`plotregion'.xscale.curmin' `y0'	///
				 `.`plotregion'.xscale.curmax' `y1'
		}
	    }
	}

							// draw ticks
	if "`pos'" == "left" | "`pos'" == "right" {
		if ! `gridonly' {
			.`plotregion'.style.margin.setgdi, view(`.objkey') yonly
		}
		.`plotregion'.yscale.setgdi `.ysize_ren'
	}
	else {
		if ! `gridonly' {
			.`plotregion'.style.margin.setgdi, view(`.objkey') xonly
		}
		.`plotregion'.xscale.setgdi `.xsize_ren'
	}

	if `gridonly' {
		local x0 = - `.`plotregion'.style.margin.gmleft'
		local y0 = - `.`plotregion'.style.margin.gmbottom'
	}

	foreach ticks in minor minornl major majornl {

		local drawgrid = `gridonly' & 0`.style.draw_`ticks'_grid.istrue'
//		local gridonly = 0`.draw_view.isfalse'
//		local gridonly = `gridonly' | 0`.draw_view.isfalse'

		if "`pos'" == "left" | "`pos'" == "right" {
		    .`ticks'.draw `.style.`ticks'style.objkey'	///
			`pos' `x0'				///
			0`drawgrid'				///
			0`gridonly'				///
			0`.`plotregion'.xsize_ren'		///
			0`.`plotregion'.style.margin.gmleft'	///
			0`.`plotregion'.style.margin.gmright'	///
			"`._value_label_series y'"

		}
		else {
		    .`ticks'.draw `.style.`ticks'style.objkey'	///
			`pos' `y0'				///
			0`drawgrid'				///
			0`gridonly'				///
			0`.`plotregion'.ysize_ren'		///
			0`.`plotregion'.style.margin.gmbottom'	///
			0`.`plotregion'.style.margin.gmtop'		///
			"`._value_label_series x'"

		}
		gdi update
	}

	if ! `gridonly' {
		._draw_title `xtitle' `ytitle' `xtitlesz' `ytitlesz'
	}
	else {
		.xtransform.reset		/* back to transform when */
		.ytransform.reset		/* .axis was called 	  */
	}

exit


						/* Draw major ticks */
local fmt `.label_format'
local delta = (`.max' - `.min') / (`.numticks'-1)
local y0_0 `y0'
local x0_0 `x0'

if "`pos'" == "below" | "`pos'" == "above" { 
	.`plotregion'.style.margin.setgdi, view(`.objkey') xonly

	if "`pos'" == "below" {
		local y0 = `y0' - `.style.tickstyle.tick0'
		local y1 = `y0' + `.style.tickstyle.length.gmval'
	}
	else {
		local y0 = `y0' + `.style.tickstyle.tick0'
		local y1 = `y0' - `.style.tickstyle.length.gmval'
	}

	.`plotregion'.xscale.setgdi `.xsize_ren'

	if ! `.style.extend' {			/* draw main line */
	    if "`.style.linestyle.color.snm'" != "none" {
		gdi line `.min' `y0_0' `.max' `y0_0'
		`crt' ._declare_array axis_line
		`crt' .Declare axis_line = .line_g.new `.min' `y1'  /*
		      */ `.max' `y1',				  /*
		      */ styleref(`.style.linestyle.objkey')
	    }
	}
if `._created.istrue' & ! `._recreate.istrue' & "`crt'" != "" {
._drawem2 custom_labels x `y0_0' `pos' 
exit
}

	.style.tickstyle.setgdifull , 				/*
		*/ angle(`.style.tickangle.val') posdefault(`pos')

	local x = `.min'				/* ticks */
	forvalues i = 1/0`.numticks' {
		gdi line `x' `y0' `x' `y1'
		local x = `x' + `delta'
	}

							/* labels */
	if `.style.tickstyle.show_labels.istrue' {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美撒尿777hd撒尿| 欧美激情自拍偷拍| 91九色02白丝porn| 在线看国产日韩| 日韩一级大片在线| 久久综合九色欧美综合狠狠| 欧美成人三级在线| www成人在线观看| 17c精品麻豆一区二区免费| 洋洋成人永久网站入口| 欧美性大战久久久久久久蜜臀| 在线免费观看日本欧美| 亚洲国产综合视频在线观看| 麻豆91小视频| 97精品国产97久久久久久久久久久久 | 国内国产精品久久| 色综合网色综合| 欧美一区日本一区韩国一区| 久久综合一区二区| 欧美美女一区二区| 国产精品嫩草久久久久| 美国十次综合导航| 欧美视频一区二区三区在线观看| 国产午夜亚洲精品不卡| 久久爱www久久做| 欧美电影一区二区三区| 亚洲激情五月婷婷| 成人国产视频在线观看| 国产成人亚洲综合a∨猫咪| 欧美视频在线一区二区三区| 亚洲裸体xxx| 欧美一区二区美女| 日本不卡在线视频| 国产成人精品三级麻豆| 欧美日韩高清在线| 麻豆成人久久精品二区三区小说| 91黄色免费网站| 欧美视频中文一区二区三区在线观看| 亚洲欧美日韩国产综合在线| 成人v精品蜜桃久久一区| 日本一二三不卡| 日本高清不卡视频| 免费在线一区观看| 日本精品视频一区二区三区| 成人一区二区三区中文字幕| 国产精品剧情在线亚洲| 国产99久久久精品| 午夜精品久久一牛影视| 久久精品欧美一区二区三区不卡| 成人黄色在线网站| 美女视频免费一区| 自拍偷拍欧美激情| 午夜精品国产更新| wwwwww.欧美系列| 91精品国产综合久久精品| 久久www免费人成看片高清| 亚洲一区二区三区四区在线免费观看| 这里只有精品电影| 99re这里只有精品视频首页| 亚洲永久精品大片| 99re亚洲国产精品| 国产99久久久国产精品潘金| 成人小视频在线| 全国精品久久少妇| 日本视频一区二区三区| 亚洲gay无套男同| 午夜精品国产更新| 另类小说欧美激情| 精品国产凹凸成av人导航| 欧美另类久久久品| 欧美日韩成人一区| 日韩一区二区免费高清| 日韩午夜激情av| 欧美va亚洲va| 中文字幕免费在线观看视频一区| 91精品免费在线观看| 欧美日韩精品一区二区三区蜜桃| 欧美日韩精品二区第二页| 国产激情偷乱视频一区二区三区| 麻豆中文一区二区| 成人午夜私人影院| 色88888久久久久久影院野外| av资源网一区| 在线观看国产91| 久久婷婷国产综合精品青草| 最新高清无码专区| 美女网站色91| 在线视频国内一区二区| 久久久久久久久免费| 亚洲日本免费电影| 国产精品自在在线| 欧美日韩1区2区| 亚洲乱码中文字幕综合| 成人午夜在线免费| 欧美视频在线一区| 亚洲女同ⅹxx女同tv| 国产麻豆成人传媒免费观看| 欧美剧在线免费观看网站| 国产精品麻豆视频| 国产999精品久久久久久绿帽| 日韩欧美视频一区| 免费看精品久久片| 亚洲成人免费视频| aaa欧美色吧激情视频| 中文字幕乱码久久午夜不卡 | 成人一二三区视频| 久久日一线二线三线suv| 亚洲18女电影在线观看| 欧美日韩国产综合一区二区三区 | 国产成人午夜精品影院观看视频 | 午夜亚洲福利老司机| 色婷婷狠狠综合| 一区二区三区在线视频播放| 欧美视频在线播放| 亚洲丰满少妇videoshd| 欧美一区二区三区免费在线看| 免费看欧美美女黄的网站| 久久精品99国产国产精| 久久久噜噜噜久久中文字幕色伊伊| 极品尤物av久久免费看| 欧美国产精品一区二区| 日本韩国一区二区三区视频| 日韩制服丝袜先锋影音| 国产精品久久久久永久免费观看| 欧美综合亚洲图片综合区| 久久―日本道色综合久久| 丰满亚洲少妇av| ●精品国产综合乱码久久久久| 欧美日韩一区二区三区四区五区| 黄一区二区三区| 亚洲一区二区精品3399| 久久色在线观看| 制服丝袜中文字幕一区| 91蜜桃婷婷狠狠久久综合9色| 精品一区二区三区不卡| 亚洲va欧美va人人爽午夜| 亚洲精品日韩综合观看成人91| 久久影院电视剧免费观看| 欧美日韩aaa| 日韩三级视频在线看| 欧美电影在哪看比较好| 99精品欧美一区二区三区综合在线| 久久se精品一区精品二区| 日韩高清不卡一区二区| 一区视频在线播放| 国产精品免费视频网站| 中文一区在线播放| 国产精品高潮呻吟| 日韩一区在线播放| 亚洲一区二区成人在线观看| 亚洲女人小视频在线观看| 亚洲成人免费观看| 激情综合色播激情啊| 国产成人av一区二区三区在线| 丁香五精品蜜臀久久久久99网站 | 亚洲免费在线电影| 午夜精品久久久久久| 狠狠网亚洲精品| 成人黄色电影在线| 亚洲激情五月婷婷| 国产精品一区在线观看乱码 | 成人av小说网| 88在线观看91蜜桃国自产| 精品国产在天天线2019| 国产精品久久久久影院亚瑟| 一区二区三区欧美日韩| 国产精品主播直播| 欧美色倩网站大全免费| 久久久av毛片精品| 亚洲日本一区二区| 国产盗摄一区二区| 777久久久精品| 国产精品久久久久一区二区三区| 蜜桃av一区二区三区电影| 91香蕉国产在线观看软件| 精品国产污网站| 日本最新不卡在线| 欧美体内she精高潮| 自拍偷自拍亚洲精品播放| 丁香激情综合五月| 国产精品色噜噜| 国产aⅴ精品一区二区三区色成熟| 制服丝袜日韩国产| 七七婷婷婷婷精品国产| 高清日韩电视剧大全免费| 精品日韩99亚洲| 亚洲3atv精品一区二区三区| 欧美三级视频在线观看| 日韩电影在线观看一区| 欧美精品一区二区久久久 | 亚洲色图第一区| 波多野结衣中文字幕一区二区三区 | 欧美日韩国产首页在线观看| 亚洲另类中文字| 欧美高清视频不卡网| 老鸭窝一区二区久久精品| 亚洲国产精品精华液ab| 久久精品人人做| 国产不卡一区视频| 亚洲乱码国产乱码精品精98午夜|