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

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

?? samples.c

?? seismic software,very useful
?? C
字號:
/* Copyright (c) Colorado School of Mines, 1990./* All rights reserved.                       */#include "samples.h"#define CHARSET ((XmStringCharSet)XmSTRING_DEFAULT_CHARSET)static void samplesDrawCB (Widget da, Samples *s, caddr_t call_data);static void samplesResizeCB (Widget da, Samples *s, caddr_t call_data);static void mouseDown (Widget w, Samples *s, XEvent *event);static void mouseEdit (Widget w, Samples *s, XEvent *event);static void mouseUp (Widget w, Samples *s, XEvent *event);static void windowMapped (Widget w, Samples *s, XEvent *event);static void drawOneSample (int mode, Samples *s, int i);static Dimension widgetWidth (Widget w);static Dimension widgetHeight (Widget w);Samples *samplesCreate (Widget parent, char *title,	void (*editDone)(Samples *s)){	int n,i;	Dimension width,height;	char *labels;	Widget frame,form,label,da;	Arg args[20];	Display *dpy=XtDisplay(parent);	Samples *s;		/* create frame */	n = 0;	frame = XmCreateFrame(parent,"",args,n);	XtManageChild(frame);		/* create form to manage geometry of label and drawing area */	n = 0;	form = XmCreateForm(frame,"",args,n);	XtManageChild(form);		/* create label gadget at top of form */	n = 0;	XtSetArg(args[n],XmNlabelType,XmSTRING); n++;	labels = XmStringCreateLtoR(title,CHARSET);	XtSetArg(args[n],XmNlabelString,labels); n++;	XtSetArg(args[n],XmNtopAttachment,XmATTACH_FORM); n++;	XtSetArg(args[n],XmNtopOffset,2); n++;	XtSetArg(args[n],XmNleftAttachment,XmATTACH_FORM); n++;	XtSetArg(args[n],XmNleftOffset,2); n++;	XtSetArg(args[n],XmNrightAttachment,XmATTACH_FORM); n++;	XtSetArg(args[n],XmNrightOffset,2); n++;	label = XmCreateLabelGadget(form,"",args,n);	XtManageChild(label);		/* create drawing area beneath label */	n = 0;	XtSetArg(args[n],XmNtopAttachment,XmATTACH_WIDGET); n++;	XtSetArg(args[n],XmNtopWidget,label); n++;	XtSetArg(args[n],XmNbottomAttachment,XmATTACH_FORM); n++;	XtSetArg(args[n],XmNbottomOffset,2); n++;	XtSetArg(args[n],XmNleftAttachment,XmATTACH_FORM); n++;	XtSetArg(args[n],XmNleftOffset,2); n++;	XtSetArg(args[n],XmNrightAttachment,XmATTACH_FORM); n++;	XtSetArg(args[n],XmNrightOffset,2); n++;	da = XmCreateDrawingArea(form,"samples",args,n);	XtManageChild(da);		/* determine width and height of drawing area */	width = widgetWidth(da);	height = widgetHeight(da);		/* initialize */	s = (Samples*)malloc(sizeof(Samples));	s->frame = frame;	s->da = da;	s->n = 16;	s->data = (float*)malloc(s->n*sizeof(float));	s->origin = 0;	s->plotValue = 1.0;	s->width = (float)width/(float)(s->n+1);	s->base = 0.5*height;	s->scale = -0.25*height/s->plotValue;	s->radius = 0.40*s->width;	if (s->radius>0.1*height) s->radius = 0.1*height;	s->editMode = DRAW;	s->editDone = editDone;		/* initialize data */	for (i=0; i<s->n; ++i)		s->data[i] = 0.0;	s->data[1] = 1.0;		/* add callbacks */	XtAddCallback(da,XmNexposeCallback,samplesDrawCB,s);	XtAddCallback(da,XmNresizeCallback,samplesResizeCB,s);		/* add event handlers */	XtAddEventHandler(da,ButtonPressMask,FALSE,mouseDown,s);	XtAddEventHandler(da,ButtonMotionMask,FALSE,mouseEdit,s);	XtAddEventHandler(da,ButtonReleaseMask,FALSE,mouseUp,s);	XtAddEventHandler(da,StructureNotifyMask,FALSE,windowMapped,s);		/* return pointer to Samples */	return s;}	void samplesSetN (Samples *s, int n){	Dimension width,height;		/* set number of samples */	s->n = n;		/* update size of sample lollypops */	width = widgetWidth(s->da);	height = widgetHeight(s->da);	s->width = (float)width/(float)(s->n+1);	s->radius = 0.40*s->width;	if (s->radius>0.1*height) s->radius = 0.1*height;}void samplesSetData (Samples *s, float *d){	s->data = d;}void samplesSetPlotValue (Samples *s, float pv){	s->plotValue = (pv!=0.0)?pv:1.0;	s->scale = -0.25*widgetHeight(s->da)/s->plotValue;}void samplesSetEditMode (Samples *s, EditMode m){	s->editMode = m;}void samplesSetOrigin (Samples *s, int i){	s->origin = i;}void samplesDraw (Samples *s){	int i;	/* erase window */	XClearWindow(XtDisplay(s->da),XtWindow(s->da));		/* draw samples */	for (i=0; i<s->n; ++i)		drawOneSample(1,s,i);}static void samplesDrawCB (Widget da, Samples *s, caddr_t call_data){	samplesDraw(s);}static void drawOneSample (int mode, Samples *s, int i){	int x,y,w,h,r;	Display *dpy=XtDisplay(s->da);	Window win=XtWindow(s->da);	GC gc;	gc = (mode ? s->gcDraw : s->gcErase);	x = (i+1)*s->width;	y = s->base;	w = s->width;	h = s->data[i]*s->scale;	r = s->radius;	XDrawLine(dpy,win,gc,x-w/2,y,x+w/2,y);	XDrawLine(dpy,win,gc,x,y,x,y+h);	if (i!=s->origin)		XFillArc(dpy,win,gc,x-r,y+h-r,2*r,2*r,0,360*64);	else		XDrawArc(dpy,win,gc,x-r,y+h-r,2*r,2*r,0,360*64);}static void samplesResizeCB (Widget da, Samples *s, caddr_t call_data){	Dimension width,height;		width = widgetWidth(da);	height = widgetHeight(da);	s->width = (float)width/(float)(s->n+1);	s->base = 0.5*height;	s->scale = -0.25*height/s->plotValue;	s->radius = 0.40*s->width;	if (s->radius>0.1*height) s->radius = 0.1*height;}static Dimension widgetWidth (Widget w){	Dimension width;	Arg arg;	arg.name = XmNwidth;	arg.value = (XtArgVal)(&width);	XtGetValues(w,&arg,1);	return width;}static Dimension widgetHeight (Widget w){	Dimension height;	Arg arg;	arg.name = XmNheight;	arg.value = (XtArgVal)(&height);	XtGetValues(w,&arg,1);	return height;}static void mouseDown (Widget w, Samples *s, XEvent *event){		/* if editing not permitted, simply return */	if (s->editMode==NONE) return;		/* begin editing */	mouseEdit(w,s,event);}static void mouseEdit (Widget w, Samples *s, XEvent *event){	int x,y,i;		/* if editing not permitted, simply return */	if (s->editMode==NONE) return;		/* get mouse coordinates */	x = event->xbutton.x;	y = event->xbutton.y;		/* determine index of nearest sample */	i = x/s->width-0.5;	if (i<0) i = 0;	if (i>s->n-1) i = s->n-1;		/* erase sample */	drawOneSample(0,s,i);		/* modify nearest sample value */	if (s->editMode==ZERO)		s->data[i] = 0.0;	else if (s->editMode==NEGATE)		s->data[i] = -s->data[i];	else		s->data[i] = (y-s->base)/s->scale;		/* draw new sample in foreground color */	drawOneSample(1,s,i);		/* if editDone function exists, call it for continuous editing */	/* if (s->editDone!=NULL) s->editDone(s); */}static void mouseUp (Widget w, Samples *s, XEvent *event){		/* if editing not permitted, simply return */	if (s->editMode==NONE) return;		/* if editDone function exists, call it */	if (s->editDone!=NULL) s->editDone(s);}static void windowMapped (Widget w, Samples *s, XEvent *event){	int n;	Arg args[20];	XGCValues gcv;		/* drawing area has been mapped */	if (event->type==MapNotify) {			/* passive grab of mouse button */		XGrabButton(XtDisplay(w),AnyButton,AnyModifier,			XtWindow(w),TRUE,			ButtonPressMask|ButtonMotionMask|ButtonReleaseMask,			GrabModeAsync,GrabModeAsync,			XtWindow(w),			XCreateFontCursor(XtDisplay(w),XC_crosshair));		/* initialize graphics contexts for drawing and erasing */		n = 0;		XtSetArg(args[n],XmNforeground,&gcv.foreground); n++;		XtSetArg(args[n],XmNbackground,&gcv.background); n++;		XtGetValues(w,args,n);		s->gcDraw = XCreateGC(XtDisplay(w),XtWindow(w),0L,NULL);		XSetForeground(XtDisplay(w),s->gcDraw,gcv.foreground);		XSetBackground(XtDisplay(w),s->gcDraw,gcv.background);		s->gcErase = XCreateGC(XtDisplay(w),XtWindow(w),0L,NULL);		XSetForeground(XtDisplay(w),s->gcErase,gcv.background);		XSetBackground(XtDisplay(w),s->gcErase,gcv.foreground);	}}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人免费在线观看入口| 亚洲人成网站精品片在线观看| 国产成人自拍网| 亚洲国产精品欧美一二99| 欧美mv日韩mv国产网站app| av在线免费不卡| 久久99久久99精品免视看婷婷| 亚洲视频免费观看| 国产欧美综合在线| 欧美一区二区三区免费在线看| 91丨porny丨最新| 国产一区二区免费看| 午夜精品aaa| 亚洲人精品午夜| 国产精品欧美久久久久无广告| 欧美成人三级电影在线| 欧美日韩一区高清| 9色porny自拍视频一区二区| 狠狠色狠狠色综合| 日本va欧美va瓶| 亚洲一线二线三线视频| 国产精品―色哟哟| 久久亚洲影视婷婷| 日韩女优av电影| 欧美日韩免费观看一区三区| 91女厕偷拍女厕偷拍高清| 国产成人免费视频网站 | 国产三级一区二区| 91精品国产色综合久久| 欧美日韩精品一区二区天天拍小说| 色综合婷婷久久| 91在线国内视频| 99精品视频一区二区三区| 成人黄色电影在线 | 欧美精品一区二区三区蜜臀| 欧美人妇做爰xxxⅹ性高电影| 91豆麻精品91久久久久久| 91在线国内视频| 色久优优欧美色久优优| 色综合久久久久久久久| 色综合激情久久| 欧美中文字幕久久| 欧美性色黄大片| 欧美午夜精品理论片a级按摩| 在线观看亚洲精品| 欧美色图第一页| 欧美精品自拍偷拍| 欧美一级欧美三级| 日韩免费观看高清完整版| 日韩欧美亚洲一区二区| www国产精品av| 久久久777精品电影网影网| 日本一区二区三区电影| 国产精品久久久爽爽爽麻豆色哟哟| 中文文精品字幕一区二区| 国产精品久久久久婷婷二区次| 一色屋精品亚洲香蕉网站| 亚洲精品中文在线影院| 日韩激情中文字幕| 国内欧美视频一区二区 | 国产麻豆9l精品三级站| 成人高清视频在线| 色av成人天堂桃色av| 欧美丰满嫩嫩电影| 久久亚洲精精品中文字幕早川悠里| 国产蜜臀av在线一区二区三区| 日韩理论片网站| 日韩av二区在线播放| 国产激情91久久精品导航| 色呦呦日韩精品| 日韩一级高清毛片| 欧美国产一区在线| 亚洲午夜在线视频| 久久精品99国产精品日本| 99在线精品免费| 日韩西西人体444www| 国产精品久线在线观看| 日本aⅴ亚洲精品中文乱码| 国产精品123| 欧美美女一区二区| 国产三级精品视频| 亚洲综合精品自拍| 国产自产v一区二区三区c| 一本久久a久久精品亚洲| 8v天堂国产在线一区二区| 国产日韩欧美不卡在线| 亚洲一区二区三区四区在线观看| 蜜臀av一区二区| 91麻豆福利精品推荐| 日韩欧美国产精品一区| 综合久久一区二区三区| 视频一区视频二区中文字幕| 成人一区二区三区视频在线观看| 欧美久久一二区| 国产精品久久久久久亚洲伦| 蜜桃av一区二区三区电影| 95精品视频在线| 久久久久国色av免费看影院| 亚洲成人av在线电影| 99在线精品观看| 久久久久久久久蜜桃| 天天做天天摸天天爽国产一区| 波多野结衣精品在线| 精品久久人人做人人爱| 亚洲国产美女搞黄色| 成人av午夜影院| ww亚洲ww在线观看国产| 秋霞午夜av一区二区三区| 91啪亚洲精品| 欧美经典三级视频一区二区三区| 免费成人结看片| 欧美三电影在线| 国产精品久久精品日日| 国产在线播放一区二区三区| 欧美日韩一区二区三区高清| 国产精品久久久久久户外露出| 激情小说欧美图片| 欧美一区二区三区在| 亚洲一区二区在线视频| 99久久精品久久久久久清纯| 欧美国产成人精品| 国精产品一区一区三区mba视频| 欧美精品九九99久久| 蜜臀av性久久久久蜜臀aⅴ | 777亚洲妇女| 亚洲二区在线视频| 欧美午夜一区二区| 亚洲精品乱码久久久久久久久 | 欧美日韩综合在线免费观看| 亚洲少妇30p| 色婷婷久久久亚洲一区二区三区 | 亚洲综合精品自拍| 在线一区二区三区四区五区| 国产亚洲精品资源在线26u| 国产在线一区观看| 久久久久久日产精品| 国产经典欧美精品| 国产欧美一区二区精品忘忧草 | 大桥未久av一区二区三区中文| 久久精品亚洲精品国产欧美| 久久99日本精品| 久久噜噜亚洲综合| 国产一区二区网址| 欧美激情一区在线| 成人av在线播放网站| 亚洲欧美精品午睡沙发| 91搞黄在线观看| 亚洲第四色夜色| 日韩美女视频一区二区在线观看| 蜜桃久久av一区| 国产欧美视频一区二区三区| 成人免费观看av| 伊人色综合久久天天| 6080午夜不卡| 国产一区二区三区久久久| 国产日产欧美一区二区三区 | 欧美一区二区在线看| 日韩精品视频网站| 精品女同一区二区| 从欧美一区二区三区| 亚洲美女在线一区| 69久久夜色精品国产69蝌蚪网| 激情丁香综合五月| 中文字幕在线一区免费| 欧美在线三级电影| 蜜桃av一区二区在线观看| 国产精品五月天| 日本韩国欧美在线| 美女www一区二区| 国产精品全国免费观看高清| 欧美在线观看18| 国产一区二区调教| 亚洲影院久久精品| 久久免费美女视频| 色香蕉成人二区免费| 青草国产精品久久久久久| 欧美激情一区二区三区在线| 欧美日韩国产天堂| 国产成人福利片| 亚洲1区2区3区4区| 国产日韩一级二级三级| 欧美日韩免费一区二区三区视频| 国产美女精品一区二区三区| 亚洲综合自拍偷拍| 久久色成人在线| 欧美男人的天堂一二区| 成人中文字幕合集| 免费在线看一区| 亚洲精品成人悠悠色影视| 欧美精品一区二区三区四区 | 中文字幕第一页久久| 欧美日韩国产影片| 99精品一区二区三区| 日本不卡中文字幕| 亚洲乱码国产乱码精品精小说| 欧美v亚洲v综合ⅴ国产v| 在线观看国产精品网站| 成人白浆超碰人人人人| 国产一区二区剧情av在线| 亚洲国产视频网站|