农学小作业(根据降雨量计算排灌水量)(旱地版)

news2025/1/24 11:35:05
//-------------------------------------------------------------------------------------------------------------------
//农学小作业(根据降雨量计算排灌水量)(旱地版)
//01.参考书目:ISBN-7-80734-087-8.ISBN-7-80124-644-6.
//01.农作物生长发育阶段需要消耗水份.
//02.对旱作物:水份由降雨,灌溉和土壤湿润层保水量提供.
//03.当供水不足或供水过量都会影响农作物的生产发育,进而影响产量.
//04.对于旱地作物,相应于它的不同的生育阶段,都有一个最适宜的土壤含水率范围.
//05.土壤计划湿润层深度:旱作物农田实施灌水时,计划调节控制土壤水份状况的土层深度.
//06.灌水的额度:一般以作物的适宜土壤含水量下限作为是否需要灌水的衡量指标.
//07.排水的额度:一般旱作物是不太耐淹涝的,排水以适宜土壤含水量上限为宜.
//08.以上面的考虑进行每天的土壤含水量保持和水量平衡.       
//程序编制要求:
//1.提供作物生长发育阶段耗水量表,生长发育阶段降雨量表.
//2.要求绘制农作物每天土壤含水量线,排灌图表.
//--------------------------------------------------------------------------------------------------------------------
#include <graphics.h>//包含Easyx模拟TC的BGI绘图库头文件
#include <math.h>//包含数学运算头文件
#include <stdio.h>//包含标准输入输出头文件
#include <iostream.h>//包含输入输出头文件
#include <stdlib.h>//包含标准库头文件
#include <string.h>//包含字符串函数头文件
#include <conio.h>//
//宏定义农作物数据------------------------------------------------------------
#define M 5//矩阵行数(作物生育阶段)
#define N 5//矩阵列数(每阶段天数及水量)
#define r_w_a 390//全生育期耗水量(mm)
#define d_start 20130615//生育期起始日期
#define w_start 120//起始土层含水量(mm)
#define th_start 300//起始湿润层厚度(mm)
#define th_incre 0.324//湿润层保水比率
#define d_pervasion 0.0//日平均渗透量(mm)
//宏定义窗口格式数据----------------------------------------------------------
#define DD 40//宏定义标题边框距离
#define DW 10//宏定义宽度边框距离
#define DH 10//宏定义高度边框距离
#define DC 200//宏定义控件区域宽度
#define c1 RGB(38,47,86)//宏定义辅助线颜色1
#define c2 RGB(38,47,86)//宏定义辅助线颜色2
#define c3 RGB(255,255,255)//宏定义文字及边框颜色
#define cc1 RGB(255,0,0)//宏定义曲线颜色1(红色)
#define cc2 RGB(0,255,0)//宏定义曲线颜色2(绿色)
#define cc3 RGB(0,0,255)//宏定义曲线颜色3(蓝色)
#define cc4 RGB(255,255,0)//宏定义曲线颜色4(黄色)
#define cc5 RGB(0,255,255)//宏定义曲线颜色5(青色)
#define cc6 RGB(0,255,0)//宏定义曲线颜色6(绿色)
#define cc7 RGB(255,0,255)//宏定义曲线颜色7(品红)
#define cc8 RGB(0,0,255)//宏定义曲线颜色8(蓝色)
//定义结构体-------------------------------------------------------------------------------------------------------
struct node
{
	int numberical;//序号
    long serialnumber;//日期
    char date[10];//降雨量数据
    struct node *next;//链表指针
};//结束结构体定义
//定义农作物全局变量------------------------------------------------------------------------------------------------
static double a[M][N]={//生育阶段天数+耗水百分比+期末土壤计划湿润厚度+适宜含水率下限+适宜含水率上限
	{23,20.2,400,19.44,32.4},//1.苗期
	{20,30,500,19.44,32.4},//2.拔节
	{22,22,600,19.44,32.4},//3.抽穗
	{25,20.5,700,19.44,32.4},//4.灌浆
	{10,7.3,700,19.44,32.4}//5.成熟
};//定义双精度数组(作物生育阶段耗水规律)
double b[M+1]={d_start};//日期数组
double c[M]={a[0][0]};//生长发育阶段累计天数
double incre[400]={0.0};//每天的湿润层增量
double thickness[400][10]={0};//每天的湿润层厚度
double every_d_r[400][10]={0};//雨水量表
double every_d_w[400][10]={0};//水位量表	
double a_d=0,m_w=100.0;//全天数
int i=0,j=0,k=0,m=0,n=0,p=0;//定义整型变量
double mm,nn,pp;//
char is1[20],is2[20],is3[20],is4[20],is5[20],is6[20],is7[20],is8[20],is9[20],is10[20],is11[20],is12[20],is13[20],is14[20],is15[20];//
double d1,d2,d3,d4,d5,d6,d7,d8,d9,d10,d11,d12,d13,d14,d15;
struct node *create();//子函数原型声明
//定义窗口全局变量-------------------------------------------------------------------------------------------------
int W = GetSystemMetrics(SM_CXSCREEN);//获取整个屏幕右下角X坐标
int H = GetSystemMetrics(SM_CYSCREEN);//屏幕Y坐标
double xstep;//
double ystep;//
int c_h=26;//定义控件高度
int c_x1=W-DW-DC,c_x2=W-DW;//控件左右x坐标
int c_y1=H-DH;//第1个控件下y坐标	
//函数声明---------------------------------------------------------------------------------------------------------
double r_m_d(double d);//日期函数
void sub_frame();//绘制框架子函数
void sub_calculate();//计算数据子函数
void rain_table();//获取降雨量图表
void phase(double i,double *l_r,double *h_r,double *cost);//根据天数返回:(下限率+上限率+耗水量)
void phase1(double i,double *d1,double *d2);//根据天数返回:日期+阶段编号
void sub_text();//填写字符串
//主函数-----------------------------------------------------------------------------------------------------------
void main()
{
	rain_table();//获得降雨量图表
	//1.获得全生育阶段天数------------------------------
	for(i=0;i<M;i++){a_d=a_d+a[i][0];}//全生育阶段天数
	//2.获得全生育阶段日期数组--------------------------
	for(i=0;i<M;i++)
	{
		b[i+1]=b[i]+a[i][0];//
		b[i+1]=r_m_d(b[i+1]);//日期
	}//结束for
	//3.获得每天的湿润层增量------------------------------
	for(i=0;i<a[0][0];i++)
	{
		incre[i]=(a[0][2]-th_start)/(1.0*a[0][0]);
	}//
	k=a[0][0];//末地址
	for(i=1;i<M;i++)
	{
		m=0;//
		while(k<a_d && m<=a[i][0]-1)
		{//
			incre[k]=(a[i][2]-a[i-1][2])/(1.0*a[i][0]);//
			k++;//
			m++;//
		}//
	}//
	//for(i=0;i<a_d;i++){cout<<"incre["<<i<<"]="<<incre[i]<<endl;}
	//4.获得每天的日初日末湿润层计划厚度--------------------
	thickness[0][0]=0;//累计天数
	thickness[0][1]=th_start;//起始厚度
	thickness[0][2]=th_start+incre[0];//末了厚度
	thickness[0][3]=thickness[0][1]*a[0][3]*0.01;//适宜含水量下限
	thickness[0][4]=thickness[0][1]*a[0][4]*0.01;//适宜含水量上限
	for(i=1;i<a_d;i++)
	{
		thickness[i][0]=i;//累计天数
		thickness[i][1]=thickness[i-1][2];//起始厚度
		thickness[i][2]=thickness[i][1]+incre[i];//末了厚度
		//根据天数返回阶段
		phase1(i,&mm,&nn);//
		//根据阶段计算含水量下限
		thickness[i][3]=thickness[i][1]*a[int(nn-1)][3]*0.01;//适宜含水量下限
		thickness[i][4]=thickness[i][1]*a[int(nn-1)][4]*0.01;//适宜含水量上限
	}//
	//for(i=0;i<a_d;i++){cout<<thickness[i][0]<<"_"<<thickness[i][1]<<"_"<<thickness[i][2]<<endl;}
	//---------------------------------------------------------------------------------------------
	sub_frame();//绘图初始化
	MOUSEMSG m;//定义鼠标消息 
	while(true)//循环
	{
		m=GetMouseMsg();//获取一条鼠标消息 
		switch(m.uMsg)//根据获得的消息选择分支
		{
		case WM_LBUTTONDOWN://鼠标左键单击时判断数据输入
			{
				if(m.x>=DW && m.x<=W-DW-DC)
				{
					sub_calculate();//调用计算绘图函数
					//根据鼠标位置获得日期
					int date=(m.x-DW)/xstep;
					phase1(date,&d1,&d2);//1.日期+2.阶段编号
					d3=a[int(d2-1)][0];//3.天数
					d4=a[int(d2-1)][1];//4.需水百分比
					d5=r_w_a*d4*0.01/(1.0*d3);//5.每天耗水量
					d11=every_d_r[date][1];//11.当天降雨量
					d6=incre[date];//6.计划湿润层厚度增量
					d7=thickness[date][1];//7.日初润湿层厚度
					d8=thickness[date][2];//8.日末润湿层厚度
					d9=thickness[date][3];//9.适宜含水量下限
					d10=thickness[date][4];//10.适宜含水量上限
					d12=incre[date]*th_incre;//12.润湿层保水增量
					d13=every_d_w[date][1];//13.排灌前含水量
					d14=every_d_w[date][3];//14.需排灌含水量
					d15=every_d_w[date][2];//15.排灌后含水量
					//
					sub_text();//字符函数
				}//结束if
				break;//
			}//结束case(结束鼠标左键单击事件消息处理)
		case WM_RBUTTONDOWN://鼠标移动的时候画个空心的圆
			return;//返回while
		}//结束switch(结束鼠标消息)
	}//结束while
}//结束主函数
double r_m_d(double d)
{
	//1.取年月日
	double d1;//
	int year=0,month=0,day=0,leap=0;//年月日,(闰年2月29天)(平年2月29天)
	year=d/10000;//年
    month=(d-year*10000)/100;//月
	day=(d-year*10000-month*100);//日
	//cout<<"年_"<<year<<"月_"<<month<<"日_"<<day<<endl;
	//特殊情况(闰年)------------------------------------------------
	if(year%400==0 || (year%4==0&&year%100!=0))//判断是不是闰年
		leap=1;
	else//
		leap=0;
	//圆整日期------------------------------------------------------
	if(month==1&&day>31){day=day-31;month++;}
	if(month==2&&day>28&&leap==0){day=day-28;month++;}
	if(month==2&&day>29&&leap==1){day=day-29;month++;}
	if(month==3&&day>31){day=day-31;month++;}
	if(month==4&&day>30){day=day-30;month++;}
	if(month==5&&day>31){day=day-31;month++;}
	if(month==6&&day>30){day=day-30;month++;}
	if(month==7&&day>31){day=day-31;month++;}
	if(month==8&&day>31){day=day-31;month++;}
	if(month==9&&day>30){day=day-30;month++;}
	if(month==10&&day>31){day=day-31;month++;}
	if(month==11&&day>30){day=day-30;month++;}
	if(month==12&&day>31){day=day-31;month=month-12;year++;}
	//返回日期------------------------------------------------------
	d1=year*10000+month*100+day;
	return d1;
}//结束子函数
//-------------------------------------------------------------------------------------------------------------------
//读入txt文件到链表的函数
/* 以下是rain.txt文本文件保持原来格式
001 20130615 46.7
002 20130624 11.4
003 20130629 11.8
004 20130702 8.9
005 20130703 9.1
006 20130724 7.3
007 20130813 27.1
008 20130818 20.7
009 20130827 14.6
010 20130828 1.2
011 20130830 5.4
012 20130905 5.0
013 20130908 9.2
*/
void rain_table()
{
	struct node *q;//定义链表指针
	q=create();//调用函数读取txt文件到链表,并获取链表首地址	
}//结束主函数
//子函数
struct node *create()
{
	FILE *fp;//定义文件指针
	struct node *head,*tail,*p;//定义三个链表指针
	char bal[30];//定义字符数组
	int i,j=0,m=0,n=0;//定义整型变量
	int max=0;//定义整型变量
	head=tail=NULL;//初始化为空
	//1.打开文件-----------------------------------------------
	if(!(fp=fopen("d:\\rain1.txt","r")))//如果打开文件失败
	{
		printf("cannot open file,\n");//输出提示
		exit(1);//退出
	}//结束if
	//2.读取文件-----------------------------------------------
	while(!feof(fp))//如果没有到文件结尾
	{
		p=(struct node *)malloc(sizeof(struct node));//分配内存区域
		m=0;//
		n=0;//
		j=0;//
		if(fgets(bal,19,fp))//从fp文件流中读取一行指定长度19的字符串到bal中
		{
			//fgets(char *buf,int bufsize,FILE *stream)
			//从文件结构体指针stream中读取数据,每次读取1行.
			//每次最多读取bufsize-1个字符(第bufsize个字符自动赋值为'\0'字符串结束符)
			//使用fgets()读取文件时,bufsize大于该行的字符总数+2(1个保存换行'\n',1个保存字符串结束符'\0').
			for(i=0;i<(int)strlen(bal);i++)//对字符串进行分类取值
			{
				if(i<3)//第1个字符
				{
					n=n*10+bal[i]-'0';//获得的字符累乘10进位得到数字标号(-'0'表示将字符转为数字)
					p->numberical=n;//存储为编号
				}
				else if(i>3&&i<12)//第5到12个字符
				{
					m=m*10+bal[i]-'0';//获得的字符累乘10进位得到数字标号(-'0'表示将字符转为数字)
					p->serialnumber=m;//存储为编号
				}
				else if(i>12 && i<17)//第14到17个字符
				{
					p->date[j]=bal[i];//存储为数据字符
					j++;//
				}//结束if_elseif
			}//结束for
			p->date[4]='\0';//数据字符读完加上结束符
			p->next=NULL;//指针指向为空
			//将读入的表添加到链表中---------------------------
			if(head==NULL)//如果是读第1个表
				head=tail=p;//为head指针和tail指针赋初值
			else//剩下的表(中间的表+最后1个表)
			{
				tail->next=p;//将新读入的表存储到链表尾端
				tail=p;//更新尾部指针
			}//结束if(添加链表)--------------------------------
		}//结束if(读取1行)
	}//结束while(读取文件结束)
	//3.关闭文件并返回链表指针--------------------------------------
	fclose(fp);//关闭文件
	return(head);//返回链表的头指针
}//结束子函数*/
//---------------------------------------------------------------------------------------------------------------
//绘制框架子函数
void sub_frame()
{
	//1.全屏效果---------------------------------------------------------------------------
	initgraph(W,H);//初始化绘图窗口
	HWND hWnd = GetHWnd();//获取窗口句柄
	LONG style = GetWindowLong(hWnd,-16);//获得窗口风格
	style = style & ~WS_CAPTION & ~WS_SIZEBOX; //窗口全屏显示且不可改变大小
	SetWindowLong(hWnd,-16,style);//设置窗口风格
	SetWindowPos(hWnd, NULL,0,0,W,H,SWP_NOZORDER);//改变窗口位置,尺寸和Z序
	//ShowCursor(FALSE);//显示时隐藏鼠标
	//------------------------------------------------------------------------------------
	//2.绘制工作区边框
	setcolor(c3);
	rectangle(DW,DD,W-DW,H-DH);//外边框
	rectangle(W-DW-DC,DD,W-DW,H-DH);//控件区域边框
	//3.输出标题
	setfont(16,0,"黑体");
	outtextxy(5,10,"农学小作业(根据降雨量计算排灌水量)(旱地版)");
	//4.输出简单说明
	RECT r={W-DW-DC+10,DD+10,W-DW-10,H-DH-10};//
	setfont(12,0,"宋体");//
	drawtext("农学小作业:\n \n \
				根据降雨量计算排灌水量(旱地版)\
				\
				\n\n\
				操作说明:\n\n\
				鼠标左键  : 数据输入\n\
				鼠标右键  : 退出程序\n\
			\n\
			左键在工作区选择日期查询\n\
			\n\n\
			\n\n\
			\
			\n", &r, DT_WORDBREAK);//
	//5.调整说明文字下面的矩形控件
	for(int i=1;i<=22;i++)
	{
		rectangle(c_x1,c_y1,c_x2,c_y1-c_h);//
		c_y1=c_y1-c_h;
	}//结束for
	//6.绘制控件说明文字
	outtextxy(c_x1+10,H-DH-22*c_h+10,"1.选择日期:");//输出字符串模拟控件文字
	outtextxy(c_x1+10,H-DH-21*c_h+10,"2.作物生育阶段:");//输出字符串模拟控件文字
	outtextxy(c_x1+10,H-DH-20*c_h+10,"3.当前阶段天数:");//输出字符串模拟控件文字
    outtextxy(c_x1+10,H-DH-19*c_h+10,"4.当前阶段耗水百分比:");//输出字符串模拟控件文字
	outtextxy(c_x1+10,H-DH-18*c_h+10,"5.当前每天耗水量(mm):");//输出字符串模拟控件文字
    outtextxy(c_x1+10,H-DH-17*c_h+10,"6.计划湿润层厚度增量(mm):");//输出字符串模拟控件文字
	outtextxy(c_x1+10,H-DH-16*c_h+10,"7.日初湿润层厚度(mm):");//输出字符串模拟控件文字
    outtextxy(c_x1+10,H-DH-15*c_h+10,"8.日末湿润层厚度(mm):");//输出字符串模拟控件文字
	outtextxy(c_x1+10,H-DH-14*c_h+10,"9.适宜含水量下限(mm):");//输出字符串模拟控件文字
	outtextxy(c_x1+10,H-DH-13*c_h+10,"10.适宜含水量上限(mm):");//输出字符串模拟控件文字
	outtextxy(c_x1+10,H-DH-12*c_h+10,"11.当天降雨量(mm):");//输出字符串模拟控件文字
	outtextxy(c_x1+10,H-DH-11*c_h+10,"12.湿润层保水增量(mm):");//输出字符串模拟控件文字
	outtextxy(c_x1+10,H-DH-10*c_h+10,"13.排灌前含水量(mm):");//输出字符串模拟控件文字
    outtextxy(c_x1+10,H-DH-9*c_h+10,"14.需排灌水量(mm):");//输出字符串模拟控件文字
	outtextxy(c_x1+10,H-DH-8*c_h+10,"15.排灌后含水量(mm):");//输出字符串模拟控件文字
	//7.初始化原始数据
	//------------------------------------------------------------
    setcolor(cc1);//说明曲线颜色
	line(W-DW-DC+10,H-DH-7*c_h+15,W-DW-DC+0.35*DC,H-DH-7*c_h+15);
	setcolor(cc2);//说明曲线颜色
	line(W-DW-DC+10,H-DH-6*c_h+15,W-DW-DC+0.35*DC,H-DH-6*c_h+15);
	setcolor(cc3);//说明曲线颜色
	line(W-DW-DC+10,H-DH-5*c_h+15,W-DW-DC+0.35*DC,H-DH-5*c_h+15);
	setcolor(cc4);//说明曲线颜色
	line(W-DW-DC+10,H-DH-4*c_h+15,W-DW-DC+0.35*DC,H-DH-4*c_h+15);
	setcolor(cc5);//说明曲线颜色
	line(W-DW-DC+10,H-DH-3*c_h+15,W-DW-DC+0.35*DC,H-DH-3*c_h+15);
	setcolor(cc6);//说明曲线颜色
	line(W-DW-DC+10,H-DH-2*c_h+15,W-DW-DC+0.35*DC,H-DH-2*c_h+15);
	setcolor(cc7);//说明曲线颜色
	line(W-DW-DC+10,H-DH-1*c_h+15,W-DW-DC+0.35*DC,H-DH-1*c_h+15);
	//------------------------------------------------------------
	setcolor(c3);//说明文字颜色
	outtextxy(W-DW-DC+0.4*DC,H-DH-7*c_h+10,"1.适宜含水量下限");//写控件字符串
    outtextxy(W-DW-DC+0.4*DC,H-DH-6*c_h+10,"2.适宜含水量上限");//写控件字符串
	outtextxy(W-DW-DC+0.4*DC,H-DH-5*c_h+10,"3.土壤计划湿润层厚度");//写控件字符串
	outtextxy(W-DW-DC+0.4*DC,H-DH-4*c_h+10,"4.当天耗水量(L)");//写控件字符串
	outtextxy(W-DW-DC+0.4*DC,H-DH-3*c_h+10,"5.当天降雨量(L)");//写控件字符串
	outtextxy(W-DW-DC+0.4*DC,H-DH-2*c_h+10,"6.当天含水量线");//写控件字符串
	outtextxy(W-DW-DC+0.4*DC,H-DH-1*c_h+10,"7.当天排灌量");//写控件字符串
	//------------------------------------------------------------
}//结束子程序
//计算数据子函数
void sub_calculate()
{
	//1.计算变量初始化==-------------------------------------------------------------
	int flag;
	double d_current,d_next,current,d_f;//
	double l_r,h_r,low,up,plenty,drain,fill,cost;//下限+上限+当前+排水+灌水+耗水
	double low1,up1,plenty1,drain1,fill1,cost1;
	double d_plus,d_minus,d_drain,d_fill,current_n,current_f;//
	double d_plus1,d_minus1,d_drain1,d_fill1,current_n1,current_f1;//
	//2.生长发育阶段累计天数---------------------------------------------------------
	for(i=0;i<M-1;i++){c[i+1]=c[i]+a[i+1][0];}//
	//3.雨水量表初始化---------------------------------------------------------------
	d_current=d_start;
	for(i=0;i<a_d;i++)
	{
		d_current=r_m_d(d_current);//0.当前日期
		every_d_r[i][0]=d_current;//
		d_current=d_current+1;//
	}//
	//4.按照日期存储雨水量-----------------------------------------------------------
	struct node *q;//定义链表指针
	q=create();//调用函数读取txt文件到链表,并获取链表首地址
	while(q!=NULL)
	{
		for(i=0;i<a_d;i++)
		{
			if(q->serialnumber == every_d_r[i][0]){every_d_r[i][1]=atof(q->date);}//按照日期存储雨水量
		}//结束for
		q=q->next;//链表中的下个表
	}//结束while
	//5.绘制当天含水量线及计算当天排灌量-----------------------------------------------
	d_current=d_start;//起始日期
	current=w_start;//起始含水量
	for(i=0;i<a_d;i++)
	{		
		d_current=r_m_d(d_current);//0.当前日期
		d_next=d_current+1;
		d_next=r_m_d(d_next);//1.下一日期		
		//当天是否排灌--------------------------------------------------------------------
		phase(i,&l_r,&h_r,&cost);//调用子函数计算当前阶段的(下限率+上限率+耗水量)
		d_plus=every_d_r[i][1]+incre[i]*th_incre;计算水的增量(降雨量+保水增量)		
		d_minus=cost;//计算水的减量(耗水量)		
		current_n=current+d_plus-d_minus;//计算自然状态下含水量
		low=thickness[i][1]*l_r*0.01;//计算当天含水量下限=7.日初润湿层厚度*下限率
		up=thickness[i][1]*h_r*0.01;//计算当天含水量上限=7.日初润湿层厚度*上限率
		//判断是否需要进行排灌
		if(current_n > low && current_n <= up)//1.不需要人工干预
		{
			flag=0;
			current_f=current_n;//当天末了水位
		}
		else if(current_n <= low)//2.需要灌水
		{
			flag=1;
			fill=up-current_n;//灌水量
			current_f=up;//当天末了水位
		}
		else if(current_n > up)//3.需要排水
		{
			flag=2;
			drain=current_n-up;//排水量
			current_f=up;//当天末了水位
		}
        switch(flag)
		{
		case 0:current_f=current_n;break;//
		case 1:current_f=current_n+fill;break;//
		case 2:current_f=current_n-drain;break;//
		default:printf("data error.");break;//
		}//结束switch
		//存储当前日期和起始含水量和末了含水量
		every_d_w[i][0]=d_current;//日期
		every_d_w[i][1]=current;//日初含水量
		every_d_w[i][2]=current_f;//日末含水量
		//存储当前日期排灌水位
		switch(flag)
		{
		case 0:d_f=0;break;//
		case 1:d_f=fill;break;//
		case 2:d_f=-drain;break;//
		default:printf("data error.");break;//
		}//结束switch
		every_d_w[i][3]=d_f;//排灌水量
		//------------------------------------------------------------
		current=current_f;//下个当前日水位
		d_current=d_current+1;//逐日计算(下个当前日日期)
	}//结束for
	//6.绘制工作区坐标线
	//a.画x1轴刻度标线及文字(作物生长日期每天)--------------------------------------
	double value;//定义双精度变量
	char stt[10];//定义字符数组
	int acc_d=0;//累加天数
	xstep=(W-2*DW-DC)/(1.0*a_d);//x方向步长(nx个刻度)(对应的绘图单位)
	ystep=(H-DH-DD)/(10.0);//y方向步长(ny个刻度)(对应的绘图单位)
	for(int i=0;i<=a_d;i++)
	{
		setcolor(c1);//颜色
		line(DW+xstep*i,H-DH,DW+xstep*i,DD);//画竖直小刻度线
	}//结束for
    //b.画x2轴刻度标线及文字(作物生长日期每阶段)---------------------------
	outtextxy(DW+xstep*acc_d-10,H-DH-20,gcvt(b[0],8,stt));//在规定的位置放置字符串
	for(i=0;i<=M;i++)
	{
		setcolor(c3);//竖直辅助线颜色
		line(DW+xstep*acc_d,H-DH,DW+xstep*acc_d,DD);//画竖直小刻度线
		acc_d=acc_d+a[i][0];//累加天数
		setcolor(c3);//文字颜色
		value=b[i+1];//所在的刻度数值
		gcvt(value,8,stt);//将浮点数value转换为字符串stt
		outtextxy(DW+xstep*acc_d-10,H-DH-20,stt);//在规定的位置放置字符串
	}//结束for
	//c.画y1轴刻度标线及文字(耗水量)-----------------------------------------------
	for(i=0;i<=10.0;i++)
	{
		setcolor(c2);//水平辅助线颜色
		line(DW,DD+ystep*i,W-DW-DC,DD+ystep*i);//画水平小刻度线
		setcolor(c3);//文字颜色
		value=ystep*(10.0-i)*100.0/(H-DH-DD);//所在的刻度数值
		gcvt(value,3,stt);//将浮点数value转换为字符串stt
		outtextxy(DW+15,DD+ystep*i+5,stt);//在规定的位置放置字符串
	}//结束for
	//d.画y2轴刻度标线及文字(耗水量)-----------------------------------------------
	for(i=0;i<=10.0;i++)
	{
		setcolor(c2);//水平辅助线颜色
		line(DW,DD+ystep*i,W-DW-DC,DD+ystep*i);//画水平小刻度线
		setcolor(c3);//文字颜色
		value=1000.0-ystep*(10.0-i)*1000.0/(H-DH-DD);//所在的刻度数值
		gcvt(value,3,stt);//将浮点数value转换为字符串stt
		outtextxy(W-2*DW-DC-15,DD+ystep*i+5,stt);//在规定的位置放置字符串
	}//结束for
	//e.绘制降雨量------------------------------------------------------------------
	for(i=0;i<a_d;i++)
	{
		setcolor(cc5);//当天雨水量
		line(DW+xstep*i,H-DH-ystep*0.1*every_d_r[i][1],DW+xstep*(i+1),H-DH-ystep*0.1*every_d_r[i][1]);//画竖直小刻度线
	}//结束for
	//f.绘制耗水量------------------------------------------------------------------
	acc_d=0;
	for(i=0;i<=M;i++)
	{
		setcolor(cc4);//当天耗水量
		line(DW+xstep*acc_d,H-DH-ystep*0.1*(a[i][1]*r_w_a*0.01/a[i][0]+d_pervasion),DW+xstep*(acc_d+a[i][0]),H-DH-ystep*0.1*(a[i][1]*r_w_a*0.01/a[i][0]+d_pervasion));//画竖直小刻度线
		acc_d=acc_d+a[i][0];//累加天数
		//cout<<DW+xstep*acc_d<<" "<<DW+xstep*(acc_d+a[i][0])<<" "<<H-DH-ystep*0.1*a[i][2]<<endl;
	}//结束for
	//g.绘制计划湿润层厚度------------------------------------------------------------------
	for(i=0;i<a_d;i++)
	{
		setcolor(cc6);//计划湿润层厚度
		line(DW+xstep*i,DD+ystep*0.01*thickness[i][1],DW+xstep*(i+1),DD+ystep*0.01*thickness[i][2]);//画竖直小刻度线
		//rectangle(DW+xstep*i-2,DD+ystep*0.01*thickness[i][1]+2,DW+xstep*i+2,DD+ystep*0.01*thickness[i][1]-2);//
		//cout<<DD+ystep*0.01*thickness[i][1]<<endl;//1000.0-ystep*(10.0-i)*1000.0/(H-DH-DD)
	}//结束for
	//h.绘制适宜含水量上下限------------------------------------------------------------------
	for(i=0;i<a_d;i++)
	{
		setcolor(cc4);//适宜含水量下限
		line(DW+xstep*i,DD+ystep*0.01*thickness[i][3],DW+xstep*(i+1),DD+ystep*0.01*thickness[i][3]);//画竖直小刻度线
		//rectangle(DW+xstep*i-2,DD+ystep*0.01*thickness[i][3]+2,DW+xstep*i+2,DD+ystep*0.01*thickness[i][3]-2);//
		setcolor(cc5);//适宜含水量上限
		line(DW+xstep*i,DD+ystep*0.01*thickness[i][4],DW+xstep*(i+1),DD+ystep*0.01*thickness[i][4]);//画竖直小刻度线
		//rectangle(DW+xstep*i-2,DD+ystep*0.01*thickness[i][4]+2,DW+xstep*i+2,DD+ystep*0.01*thickness[i][4]-2);//
		//cout<<DD+ystep*0.01*thickness[i][3]<<endl;//1000.0-ystep*(10.0-i)*1000.0/(H-DH-DD)
	}//结束for
	//i.绘制当天水位线--------------------------------------------------------------
	for(i=0;i<a_d;i++)
	{
		setcolor(cc6);//6.当天水位线
		line(DW+xstep*i,DD+ystep*0.01*every_d_w[i][1],DW+xstep*(i+1),DD+ystep*0.01*every_d_w[i][2]);//画竖直小刻度线
		rectangle(DW+xstep*i-2,DD+ystep*0.01*every_d_w[i][1]+2,DW+xstep*i+2,DD+ystep*0.01*every_d_w[i][1]-2);//
	}//结束for	
	//j.绘制当天排灌量--------------------------------------------------------------
	for(i=0;i<a_d;i++)
	{
		if(every_d_w[i][3] >0){setcolor(cc7);}
		if(every_d_w[i][3] <0){setcolor(cc8);}
		if(every_d_w[i][3] !=0)
		{
			line(DW+xstep*(i+0.5),DD+ystep*0.01*every_d_w[i][1],DW+xstep*(i+0.5),DD+ystep*0.01*(every_d_w[i][1]+every_d_w[i][3]));//画竖直小刻度线
		}//结束if
	}//结束for	
	//7.重新绘制工作区边框
	setcolor(c3);
	rectangle(DW,DD,W-DW,H-DH);//外边框
	rectangle(W-DW-DC,DD,W-DW,H-DH);//控件区域边框	
}//结束子函数
//根据天数返回:(下限率+上限率+耗水量)
void phase(double i,double *l_r,double *h_r,double *cost)//根据天数返回:(下限率+上限率+耗水量)
{
	if(i>=0 && i<c[0]){*l_r=a[0][3];*h_r=a[0][4];*cost=d_pervasion+a[0][1]*0.01*r_w_a/a[0][0];}//1.
	if(i>=c[0] && i<c[1]){*l_r=a[1][3];*h_r=a[1][4];*cost=d_pervasion+a[1][1]*0.01*r_w_a/a[1][0];}//2.
	if(i>=c[1] && i<c[2]){*l_r=a[2][3];*h_r=a[2][4];*cost=d_pervasion+a[2][1]*0.01*r_w_a/a[2][0];}//3.
	if(i>=c[2] && i<c[3]){*l_r=a[3][3];*h_r=a[3][4];*cost=d_pervasion+a[3][1]*0.01*r_w_a/a[3][0];}//4.
	if(i>=c[3] && i<c[4]){*l_r=a[4][3];*h_r=a[4][4];*cost=d_pervasion+a[4][1]*0.01*r_w_a/a[4][0];}//5.
}//结束子函数
//返回天数返回:日期+阶段编号的子函数
void phase1(double i,double *d1,double *d2)
{
	if(i>=0 && i<c[0]){*d1=i+b[0];*d2=1;}//1.
	if(i>=c[0] && i<c[1]){*d1=i-c[0]+b[1];*d2=2;}//2.
	if(i>=c[1] && i<c[2]){*d1=i-c[1]+b[2];*d2=3;}//3.
	if(i>=c[2] && i<c[3]){*d1=i-c[2]+b[3];*d2=4;}//4.
	if(i>=c[3] && i<c[4]){*d1=i-c[3]+b[4];*d2=5;}//5.
	*d1=r_m_d(*d1);//
}//结束子函数
void sub_text()
{
	//1.将计算结果转化为字符串--------------------------------------------------------------------------
	gcvt(d1,8,is1);//
	gcvt(d2,6,is2);//
	gcvt(d3,6,is3);//
	gcvt(d4,6,is4);//
	gcvt(d5,6,is5);//
	gcvt(d6,6,is6);//
	gcvt(d7,6,is7);//
	gcvt(d8,6,is8);//
	gcvt(d9,6,is9);//
	gcvt(d10,6,is10);//
	gcvt(d11,6,is11);//
	gcvt(d12,6,is12);//
	gcvt(d13,6,is13);//
	gcvt(d14,6,is14);//
	gcvt(d15,6,is15);//
	//2.将字符串写入控件中
	setfillcolor(BLACK);
	//------------------------------------------------------------
	fillrectangle(W-DW-DC+DC/2+30,H-DH-22*c_h+1,W-DW,H-DH-21*c_h);
	outtextxy(W-DW-DC+DC/2+35,H-DH-22*c_h+12,is1);//写控件字符串
	//------------------------------------------------------------
	fillrectangle(W-DW-DC+DC/2+30,H-DH-21*c_h+1,W-DW,H-DH-20*c_h);
	outtextxy(W-DW-DC+DC/2+35,H-DH-21*c_h+12,is2);//写控件字符串
	//------------------------------------------------------------
	fillrectangle(W-DW-DC+DC/2+30,H-DH-20*c_h+1,W-DW,H-DH-19*c_h);
	outtextxy(W-DW-DC+DC/2+35,H-DH-20*c_h+12,is3);//写控件字符串
	//------------------------------------------------------------
	fillrectangle(W-DW-DC+DC/2+30,H-DH-19*c_h+1,W-DW,H-DH-18*c_h);
	outtextxy(W-DW-DC+DC/2+35,H-DH-19*c_h+12,is4);//写控件字符串
	//------------------------------------------------------------
	fillrectangle(W-DW-DC+DC/2+30,H-DH-18*c_h+1,W-DW,H-DH-17*c_h);
	outtextxy(W-DW-DC+DC/2+35,H-DH-18*c_h+12,is5);//写控件字符串
	//------------------------------------------------------------
	fillrectangle(W-DW-DC+DC/2+30,H-DH-17*c_h+1,W-DW,H-DH-16*c_h);
	outtextxy(W-DW-DC+DC/2+35,H-DH-17*c_h+12,is6);//写控件字符串
	//------------------------------------------------------------
	fillrectangle(W-DW-DC+DC/2+30,H-DH-16*c_h+1,W-DW,H-DH-15*c_h);
	outtextxy(W-DW-DC+DC/2+35,H-DH-16*c_h+12,is7);//写控件字符串
	//------------------------------------------------------------
	fillrectangle(W-DW-DC+DC/2+30,H-DH-15*c_h+1,W-DW,H-DH-14*c_h);
	outtextxy(W-DW-DC+DC/2+35,H-DH-15*c_h+12,is8);//写控件字符串
	//------------------------------------------------------------
	fillrectangle(W-DW-DC+DC/2+30,H-DH-14*c_h+1,W-DW,H-DH-13*c_h);
	outtextxy(W-DW-DC+DC/2+35,H-DH-14*c_h+12,is9);//写控件字符串
	//------------------------------------------------------------
	fillrectangle(W-DW-DC+DC/2+30,H-DH-13*c_h+1,W-DW,H-DH-12*c_h);
	outtextxy(W-DW-DC+DC/2+35,H-DH-13*c_h+12,is10);//写控件字符串
	//------------------------------------------------------------
	fillrectangle(W-DW-DC+DC/2+30,H-DH-12*c_h+1,W-DW,H-DH-11*c_h);
	outtextxy(W-DW-DC+DC/2+35,H-DH-12*c_h+12,is11);//写控件字符串
	//------------------------------------------------------------
	fillrectangle(W-DW-DC+DC/2+30,H-DH-11*c_h+1,W-DW,H-DH-10*c_h);
	outtextxy(W-DW-DC+DC/2+35,H-DH-11*c_h+12,is12);//写控件字符串
	//------------------------------------------------------------
	fillrectangle(W-DW-DC+DC/2+30,H-DH-10*c_h+1,W-DW,H-DH-9*c_h);
	outtextxy(W-DW-DC+DC/2+35,H-DH-10*c_h+12,is13);//写控件字符串
	//------------------------------------------------------------
	fillrectangle(W-DW-DC+DC/2+30,H-DH-9*c_h+1,W-DW,H-DH-8*c_h);
	outtextxy(W-DW-DC+DC/2+35,H-DH-9*c_h+12,is14);//写控件字符串
	//------------------------------------------------------------
	fillrectangle(W-DW-DC+DC/2+30,H-DH-8*c_h+1,W-DW,H-DH-7*c_h);
	outtextxy(W-DW-DC+DC/2+35,H-DH-8*c_h+12,is15);//写控件字符串
	//------------------------------------------------------------	
}//结束子函数
//-----------------------------------------------------------------------------------------------------------------

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1330032.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Deepin更换仿Mac主题

上一篇博客说了要写一篇deepin系统的美化教程 先看效果图&#xff1a; 准备工作&#xff1a; 1.你自己 嘻嘻嘻 2.能上网的deepin15.11电脑 首先去下载主题 本次需要系统美化3部分&#xff1a;1.图标 2.光标 3.壁纸 开始之前&#xff0c;请先把你的窗口特效打开&#xff0c;…

【MVT_1703230471】基于Python NLTK分词、词云、LDA主题分类及GPT情感分类

【Talk is cheap】 1 数据探索 case idcase outcome case title case text 0 Case1 cited Alpine Hardwood (Aust) Pty Ltd v Hardys Pty Lt... Ordinarily that discretion will be exercised s... 1 Case2 cited Black v Lipovac [1998] FCA 699 ; (1998) 217 AL... The gen…

Epson爱普生手臂机器人与PC通讯 C#

一、Epson手臂配置 1.安装Epson手臂控制软件 安装Epson手臂控制软体EPSON RC+ 7.0(根据实际需求下载应用),可以去官网下载安装。 2.硬件配置 准备一台PC,用网线连接PC和EPSON手臂控制器。 3.在PC上修改IP地址 EPSON手臂默认IP(192.168.0.1),PC IP改为手臂同一网段…

歌曲春节回家:荆涛歌声中的深情与诗人的心声

歌曲春节回家&#xff1a;荆涛歌声中的深情与诗人的心声 在寒冬的寂静中&#xff0c;荆涛的歌声如同春风拂面&#xff0c;温暖而深情。它唤起了我们对家的思念&#xff0c;让我们感受到家的温暖和亲情的珍贵。而在歌声中&#xff0c;我们仿佛听到了那些描绘春节的经典诗句&…

pycharm修改项目文件夹名称

目录 1 修改项目文件夹名称 2 修改代码中的项目名称 1 修改项目文件夹名称 选中项目文件夹&#xff0c;右键&#xff0c;选择refactor-rename。 选择rename project&#xff1a; 然后输入新的项目名称。 此时进入资源管理器&#xff0c;修改项目文件夹的名字&#xff0c;完成…

Linux 一键部署二进制Gitea

gitea 前言 Gitea 是一个轻量级的 DevOps 平台软件。从开发计划到产品成型的整个软件生命周期,他都能够高效而轻松的帮助团队和开发者。包括 Git 托管、代码审查、团队协作、软件包注册和 CI/CD。它与 GitHub、Bitbucket 和 GitLab 等比较类似。 Gitea 最初是从 Gogs 分支而来…

EarMaster Pro 7 简体中文破解版 v7.2.0.42 电脑版

软件介绍 EarMaster破解版一款功能强大的专业级别多媒体音乐教育学习软件&#xff0c;EarMaster破解版提供了大量音乐相关的学习内容&#xff0c;用户在这里可以学习基础的和弦、音阶、节奏&#xff0c;也可以提升自己的音感&#xff0c;如果基础已经很扎实了&#xff0c;还可…

vue3 + TypeScript使用国际化

vue3 TypeScript使用国际化 本文使用了 Vite 构建工具创建的vue3项目Vite 支持使用特殊的 import.meta.glob 函数从文件系统导入多个模块Vite 官方中文文档当然如果你的vue3项目未使用vite,你也可以为你的旧项目提提速&#xff0c;安装vite &#xff0c;安装方法在上一个博客…

ubuntu 18.04 共享屏幕

用于windows远程ubuntu 1. sudo apt install xrdp 2. 配置 sudo vim /etc/xrdp/startwm.sh 把最下面的test和exec两行注释掉&#xff0c;添加一行 gnome-session 3.安装dconf-editor : sudo apt-get install dconf-editor 关闭require encrytion org->gnome->desktop…

js中将数字转成中文

文章目录 一、实现二、最后 一、实现 如果要将数字10、100和1000转换成中文的"十"、“一百"和"一千”&#xff0c;可以使用以下 JavaScript 代码实现&#xff1a; function numberToChinese(num) {const chineseNums [零, 一, 二, 三, 四, 五, 六, 七, …

华为防火墙小企业简单应用命令行配置

实现&#xff1a; 1、内网访问外网 2、内网和外网访问dmz区ftp服务器 3、开启ftp的aspf功能 4、开启内网黑洞功能 防火墙配置&#xff1a; interface GigabitEthernet1/0/0 undo shutdown ip address 10.0.0.1 255.255.255.0 service-manage ping permit interface GigabitEth…

【Hadoop】 YARN 运行过程/YARN设计目标

YARN 运行过程剖析YARN设计目标 YARN 运行过程剖析 一个Job在YARN中的处理过程&#xff1a; 客户端向RM提交一个job&#xff0c;进入RM中的调度器队列以供调度RM中的AppManager与NM协商协商好一个容器&#xff0c;以启动一个App Master实例App Master启动之后向RM注册并根据Jo…

电脑完全重装教程——原版系统镜像安装

注意事项 本教程会清除所有个人文件 请谨慎操作 请谨慎操作 请谨慎操作 前言 本教程是以系统安装U盘为介质进行系统重装操作&#xff0c;照着流程操作会清除整个硬盘里的文件&#xff0c;请考虑清楚哦&#xff5e; 有些小伙伴可能随便在百度上找个WinPE作为启动盘就直接…

清风数学建模学习笔记--灰色关联分析

一&#xff1a;内容&#xff1a;灰色关联分析 介绍&#xff1a;可以分析多个因素之间&#xff0c;哪一个对y的影响大&#xff0c;哪一个对y的影响小。之前学过回归分析中的标准化回归也可以分析&#xff0c;岭回归&#xff0c;lasso回归等都可以分析&#xff0c;那为什么要使用…

Java基础01 基础语法

文章目录 01 Java概述1、JAVA安装2、HelloWorld3、JAVA概述3.1 JAVA的发展3.2JAVA可以做什么3.2.1 JAVA SE3.2.2 JAVA ME3.2.3 JAVA EE3.2.4 总结 4、JAVA跨平台的原理5、JDK与JRE5.1 JDK5.2 JRE5.3 Other 02 基础语法1、注释2、关键字3、字面量4、变量5、计算机中的数据存储5.…

Vue3+el-table实现甘特图

Vue3 el-table实现甘特图效果 代码gitee 整体实现效果如下 进度列&#xff0c;可以通过设置天或小时&#xff0c;切换不同列显示类型。 涉及到的问题 1、通过Worker解决js线程堵塞问题 在根据时间动态生成列时&#xff0c;由于开始时间与结束时间跨度过大时&#xff0c;计…

Python 运算符 算数运算符 关系运算符 赋值运算符 逻辑运算 (逻辑运算符的优先级) 位运算 成员运算符 身份运算符 运算符的优先级

1 运算符算数运算符关系运算符赋值运算符逻辑运算逻辑运算符的优先级 位运算布尔运算符移位运算符 成员运算符身份运算符运算符的优先级 运算符 算数运算符 四则运算 - * / a 8 b 9 print(ab)#与Java类似 也可以进行字符串的连接 注意:字符串数字字符串 不存在会抛出异常…

Vue项目如何打包

1. 确保你已经在项目根目录下安装了Vue CLI。如果没有安装&#xff0c;可以通过以下命令进行安装&#xff1a; npm install -g vue/cli 2. 在项目根目录下打开终端或命令行工具&#xff0c;运行以下命令来创建一个生产环境的打包文件&#xff1a; npm run build 这个命令会执…

异丙醇蒸汽干燥晶圆法

在半导体制程中&#xff0c;大多数的朋友对于晶圆干燥的印象还停留在旋转式甩干机&#xff08;SRD&#xff09;的阶段。晶圆旋转式甩干是目前最普遍的一种晶圆甩干方式&#xff0c;但是在很多工序中&#xff0c;并不太适合用旋转式甩干机&#xff0c;那么IPA&#xff08;异丙醇…

SuperMap Hi-Fi 3D SDK for Unity基础开发教程

作者&#xff1a;kele 一、背景 众所周知&#xff0c;游戏引擎&#xff08;Unity&#xff09;功能强大&#xff0c;可以做出很多炫酷的游戏和动画效果&#xff0c;这部分功能的实现往往不仅仅是靠可视化界面就能够实现的&#xff0c;还需要代码开发。SuperMap Hi-Fi SDKS for …