cacu.c

来自「KS0108 LCD液晶模块的驱动函数 包括PROTEUS仿真图」· C语言 代码 · 共 113 行

C
113
字号
/*
****************************************************

		计算

****************************************************
*/
#include "Typedef.H"
#include "UserDef.H"

/*  全局变量 */
static float idata OpVal[2] = {0,0};	//操作数
static INT8U OpAct = VK_NULL;	//操作符



/***************************************

	四则运算
	入口参数:运算结果存储变量的指针
	返回值:运算是否成功

****************************************/
static BOOLEAN cacu(float *rv)
	{
	BOOLEAN valid;

	valid = TRUE;
	switch (OpAct)
		{
		case VK_ADD:
			(*rv) = OpVal[0] + OpVal[1];
			break;
		case VK_SUB:
			(*rv) = OpVal[0] - OpVal[1];				
			break;
		case VK_MUL:
			(*rv) = OpVal[0] * OpVal[1];
			break;
		case VK_DIV:
			(*rv) = OpVal[0] / OpVal[1];
			break;
		default:
			valid = FALSE;
			break;
		}
	return valid;
	}


/***************************************

	运算相关按键输入及处理
	入口参数:按键值,运算结果存储变量的指针
	返回值:操作是否错误

****************************************/
BOOLEAN CacuInput(INT8U kv,float * rv)
	{
	static INT8U CurI = 0;		 //当前输入对应的操作数
	BOOLEAN valid;
	
	switch (kv)
		{
		case VK_0:
		case VK_1:
		case VK_2:
		case VK_3:
		case VK_4:
		case VK_5:
		case VK_6:
		case VK_7:
		case VK_8:
		case VK_9:
			OpVal[CurI] *= 10;
			OpVal[CurI] += (kv - VK_0);
			(*rv) = OpVal[CurI];
			valid = TRUE;
			break;

		case VK_ADD:
		case VK_SUB:
		case VK_MUL:
		case VK_DIV:
			OpAct = kv;
			CurI = 1;
			OpVal[1] = 0;
			valid = TRUE;
			(*rv) = 0;
			break;

		case VK_EQU:
			valid = cacu(rv);
			OpVal[0] = *rv;
			CurI  = 1;
			break;

		case VK_CLR:
			OpAct = VK_NULL;
			CurI = 0;
			OpVal[0] = OpVal[1] = 0;
			(*rv) = 0;
			valid = TRUE;
			break;

		default:
			valid = FALSE;
			break;
		}
	
	return valid;
	}
 

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?