亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
caoporn国产一区二区| 日本电影亚洲天堂一区| 一区二区三区在线视频免费观看| 欧美日韩视频在线一区二区| 久草在线在线精品观看| 亚洲最新视频在线播放| 久久久精品欧美丰满| 欧美一区二区私人影院日本| 成人精品国产一区二区4080| 欧美aⅴ一区二区三区视频| 怡红院av一区二区三区| 久久久久成人黄色影片| 欧美一区二区日韩| 欧洲国内综合视频| 成人av电影在线网| 国内精品不卡在线| 午夜精品在线视频一区| 亚洲精选免费视频| 中文字幕中文字幕一区| 久久久.com| 精品国产91亚洲一区二区三区婷婷| 色老头久久综合| 成人永久看片免费视频天堂| 久久成人综合网| 天堂在线亚洲视频| 亚洲午夜影视影院在线观看| 国产精品伦理在线| 亚洲国产精品二十页| 精品国产91洋老外米糕| 日韩精品中文字幕在线不卡尤物| 欧美精品乱码久久久久久按摩| 91福利国产精品| 在线影院国内精品| 色综合久久九月婷婷色综合| 成人精品gif动图一区| 国产精品91一区二区| 国内精品在线播放| 国产一区二区三区在线观看免费 | 中文字幕免费在线观看视频一区| 这里只有精品免费| 91精品国产综合久久香蕉的特点| 欧美日韩一区二区三区在线| 欧美在线啊v一区| 在线观看欧美精品| 欧美日韩在线精品一区二区三区激情 | 国产在线观看一区二区| 久久爱另类一区二区小说| 秋霞电影一区二区| 久久er99热精品一区二区| 久久99国产精品尤物| 国产一区美女在线| 丰满岳乱妇一区二区三区| 国产ts人妖一区二区| 北条麻妃国产九九精品视频| 成人av资源下载| 97精品国产露脸对白| 色欧美日韩亚洲| 717成人午夜免费福利电影| 欧美一二三四在线| 国产视频一区二区在线| 一色桃子久久精品亚洲| 亚洲影视资源网| 日本成人在线不卡视频| 麻豆久久久久久| 国产91综合网| 在线观看亚洲精品视频| 欧美高清视频一二三区| 久久久噜噜噜久久中文字幕色伊伊 | 一区二区三区中文字幕在线观看| 亚洲国产精品久久艾草纯爱 | 偷拍日韩校园综合在线| 久久精品国产亚洲高清剧情介绍| 国产xxx精品视频大全| 色综合欧美在线| 91精品国产麻豆国产自产在线| 精品va天堂亚洲国产| 自拍av一区二区三区| 日韩黄色免费电影| 粉嫩av一区二区三区| 欧美色综合天天久久综合精品| 欧美一区二区视频观看视频| 国产嫩草影院久久久久| 亚洲国产另类精品专区| 国产aⅴ综合色| 欧美日韩成人在线| 国产清纯白嫩初高生在线观看91| 亚洲三级在线看| 国模娜娜一区二区三区| 91视视频在线观看入口直接观看www | 国产精品系列在线播放| 9人人澡人人爽人人精品| 91精品国产一区二区三区蜜臀| 国产亚洲va综合人人澡精品| 亚洲在线视频一区| 国产综合久久久久久久久久久久| 色哟哟一区二区在线观看| 欧美一级一级性生活免费录像| 国产精品午夜电影| 日本一不卡视频| 91免费观看国产| 久久久久国产一区二区三区四区| 亚洲亚洲精品在线观看| 成人av在线观| www国产精品av| 天天综合色天天综合色h| 成人蜜臀av电影| 欧美草草影院在线视频| 亚洲图片欧美综合| av在线不卡免费看| 久久色.com| 久久av中文字幕片| 欧美日韩黄色一区二区| 中文字幕亚洲欧美在线不卡| 精品一区在线看| 在线播放视频一区| 亚洲精品伦理在线| 91欧美一区二区| 欧美国产日本视频| 国产在线麻豆精品观看| 91麻豆精品91久久久久久清纯 | 国内精品视频666| 国产清纯白嫩初高生在线观看91 | 成人夜色视频网站在线观看| 精品日韩一区二区| 日本亚洲最大的色成网站www| 色婷婷久久久久swag精品| 国产日产欧美一区二区视频| 久久成人免费网站| 欧美福利视频导航| 亚洲影视在线观看| 欧美视频一区在线| 亚洲电影你懂得| 在线观看亚洲成人| 亚洲精品成人精品456| 91亚洲精品久久久蜜桃| 中文字幕一区二区日韩精品绯色| 成人激情黄色小说| 亚洲欧美在线另类| 91麻豆自制传媒国产之光| 国产精品久久久久久福利一牛影视| 国产成人精品免费一区二区| 精品国产乱码久久久久久蜜臀| 麻豆精品一区二区| 精品粉嫩aⅴ一区二区三区四区| 久久电影国产免费久久电影| 日韩欧美国产午夜精品| 美女一区二区久久| 欧美mv日韩mv| 成人视屏免费看| 自拍偷自拍亚洲精品播放| 91香蕉视频黄| 亚洲宅男天堂在线观看无病毒| 欧美吻胸吃奶大尺度电影| 亚欧色一区w666天堂| 91麻豆精品国产91| 久久99精品久久只有精品| 亚洲精品在线网站| 国产风韵犹存在线视精品| 中文字幕欧美日韩一区| 91日韩精品一区| 亚洲成人精品影院| 欧美变态凌虐bdsm| 成人妖精视频yjsp地址| 亚洲六月丁香色婷婷综合久久| 欧美日韩另类国产亚洲欧美一级| 无码av免费一区二区三区试看| 欧美sm极限捆绑bd| 99久久久精品| 五月天视频一区| 26uuu精品一区二区三区四区在线| 国产不卡在线一区| 亚洲精品视频在线观看网站| 欧美日韩国产影片| 国产成人无遮挡在线视频| 一区二区三区四区在线| 日韩一区二区中文字幕| 国产.欧美.日韩| 一区二区三区四区高清精品免费观看 | 成人av在线观| 亚洲第四色夜色| 国产日韩三级在线| 欧美色电影在线| 国产在线精品不卡| 亚洲电影在线免费观看| 久久免费偷拍视频| 欧美精品v日韩精品v韩国精品v| 国产成人免费在线视频| 天天综合天天综合色| 日本一区二区三区电影| 欧美放荡的少妇| 一本一本大道香蕉久在线精品 | 中文字幕乱码久久午夜不卡 | 97久久超碰国产精品电影| 日韩精品一级中文字幕精品视频免费观看| 久久亚洲精精品中文字幕早川悠里 | 成人一道本在线| 免播放器亚洲一区| 一个色综合av| 国产精品第五页| 精品国产自在久精品国产|