⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 iec104.cpp

📁 此程序适用于电力系统中的网关程序
💻 CPP
📖 第 1 页 / 共 3 页
字号:
		DataInfo.ApduHead.bControlCode1 = m_wSendCount % 0x100;
		DataInfo.ApduHead.bControlCode2 = m_wSendCount / 0x100;
		DataInfo.ApduHead.bControlCode3 = m_wRevCount % 0x100;
		DataInfo.ApduHead.bControlCode4 = m_wRevCount / 0x100;

		DataInfo.AsduHead.bAsduType =  0x32;
		DataInfo.AsduHead.bAsduVsq = (unsigned char)nNumber;//??
		DataInfo.AsduHead.nAsduCot = 0x0002;
		DataInfo.AsduHead.nAsduComAddr = m_iAddress * 0x100;//0x0100;//bNode*0x100 + bSector;
		DataInfo.AsduHead.bAsduInf = 0x00;//??

		for (i=0; i<nNumber; ++i)
		{
			g_devdata.GetFixDevData(m_nPortNo, i, DATA_YC, DataGroup);
			DataInfo.bDataVec.push_back(DataGroup.nValue & 0xff);
			DataInfo.bDataVec.push_back(DataGroup.nValue / 0xff);

		}
		//如果增加频率,可在此处添加
		m_SendList.push_back(DataInfo);
		DataInfo.bDataVec.clear();
		m_wSendCount += 2;		//最低位未使用
	}
	return;
}

/*====================================================================================
*                                                                                    
* Subroutine  : PutSendList()
*                                                                                    
* Parameters  : 
*               
*                                                                                    
* Called from : PackData()
* 
* Description : 打包主动上送信息,存入m_SendList队列中
* 
* Return	  : 
*               
*                                             
* Modification: 
*				 2004-07-29: 
*                                                                                     
*====================================================================================*/
int CIEC104::PutSendList()
{
	int			nResult = 0;	//返回值变量
	int			nResult1 = 0;	//返回值变量
	int			ret = 0;		//返回值变量
	SOE_STATUS		soe_status;		//收到信息数据结构
	DATA_STR		DataInfo;		//数据信息格式
	enum GateStation	eStation;		//站类型
	SYSTEMTIME		systime;		//时间结构体

	memset(&soe_status, 0x00, sizeof(SOE_STATUS));
	memset(&DataInfo, 0x00, sizeof(DATA_STR));

	GetGateStation(eStation);
	nResult1 = g_soedata.GetSoeData(eStation, soe_status);

	if (nResult1)
	{
		DataInfo.ApduHead.bStartCode =  0x68;
		DataInfo.ApduHead.bControlCode1 = m_wSendCount % 0x100;
		DataInfo.ApduHead.bControlCode2 = m_wSendCount / 0x100;
		DataInfo.ApduHead.bControlCode3 = m_wRevCount % 0x100;
		DataInfo.ApduHead.bControlCode4 = m_wRevCount / 0x100;

		DataInfo.AsduHead.bAsduVsq = 0x81;
		DataInfo.AsduHead.nAsduCot = 0x0001;
		DataInfo.AsduHead.nAsduComAddr = soe_status.bAddress;
//		DataInfo.AsduHead.bAsduInf = soe_status.nPot;

		if (!DataInfo.bDataVec.empty())
		{
			DataInfo.bDataVec.clear();
		}

		GetLocalTime(&systime);
		//asdu类型需要配置??
		switch (soe_status.eType)
		{
		case INFDATA_YX:	//遥信变位
			if (soe_status.nPot < 512)
			{
				DataInfo.AsduHead.nAsduComAddr = m_iAddress * 0x100 
					+ m_bSector[soe_status.nPot];//??soe_status.bAddress;
				DataInfo.AsduHead.bAsduInf = m_bYXInfBuf[soe_status.nPot];//??
			}
			else
			{
				//有问题了
			}
			DataInfo.ApduHead.bApduLength = 0x13;

			DataInfo.AsduHead.bAsduType =  0x1f;

			DataInfo.bDataVec.push_back(soe_status.bStatus);
			DataInfo.bDataVec.push_back(soe_status.wMilliseconds % 0x100);
			DataInfo.bDataVec.push_back(soe_status.wMilliseconds / 0x100);
			DataInfo.bDataVec.push_back(soe_status.bMinute);
			DataInfo.bDataVec.push_back(soe_status.bHour);
			DataInfo.bDataVec.push_back(systime.wDay & 0x1f);
			DataInfo.bDataVec.push_back(systime.wMonth & 0x1f);
			DataInfo.bDataVec.push_back(systime.wYear & 0x7f);

			m_SendList.push_back(DataInfo);
			DataInfo.bDataVec.clear();
			m_wSendCount += 2;		//最低位未使用
			nResult = 1;
			break;
		case INFDATA_SOE:
			DataInfo.AsduHead.nAsduComAddr = m_iAddress * 0x100 
				+ m_bSector[soe_status.nPot];//??soe_status.bAddress;
			ret = ReadSOEInf104(soe_status.nPot);
			if (ret!=0)
			{
				DataInfo.AsduHead.bAsduInf = ret;//??
			}
			else
			{
				break;
			}

			DataInfo.ApduHead.bApduLength = 0x13;

			DataInfo.AsduHead.bAsduType =  0x26;

			DataInfo.bDataVec.push_back(soe_status.bStatus);
			DataInfo.bDataVec.push_back(soe_status.wMilliseconds % 0x100);
			DataInfo.bDataVec.push_back(soe_status.wMilliseconds / 0x100);
			DataInfo.bDataVec.push_back(soe_status.bMinute);
			DataInfo.bDataVec.push_back(soe_status.bHour);
			DataInfo.bDataVec.push_back(systime.wDay & 0x1f);
			DataInfo.bDataVec.push_back(systime.wMonth & 0x1f);
			DataInfo.bDataVec.push_back(systime.wYear & 0x7f);

			m_SendList.push_back(DataInfo);
			DataInfo.bDataVec.clear();
			m_wSendCount += 2;		//最低位未使用
			nResult = 1;
			break;
		case INFDATA_YK_SEL:	//遥控返校,选择
		case INFDATA_YK_EXE:	//遥控返校,执行
			if (soe_status.nPot < 512)
			{
				DataInfo.AsduHead.nAsduComAddr = m_iAddress * 0x100 
					+ m_bSector[soe_status.nPot];//??soe_status.bAddress;
				DataInfo.AsduHead.bAsduInf = m_bYXInfBuf[soe_status.nPot];//??
			}
			else
			{
				//有问题了
			}
			DataInfo.ApduHead.bApduLength = 0x0c;

			DataInfo.AsduHead.bAsduType =  0x2e;

			if ((soe_status.bStatus == 1)
				|| (soe_status.bStatus == 2))
			{
				DataInfo.AsduHead.nAsduCot = 0x0007;	//肯定回答
			}
			else
			{
				DataInfo.AsduHead.nAsduCot = 0x000a;	//否定回答
			}

			if (soe_status.eType == INFDATA_YK_SEL)
			{
				DataInfo.bDataVec.push_back(soe_status.bStatus|0x80);	//选择
			}
			else
			{
				DataInfo.bDataVec.push_back(soe_status.bStatus);	//执行
			}

			m_SendList.push_back(DataInfo);
			DataInfo.bDataVec.clear();
			m_wSendCount += 2;		//最低位未使用
			nResult = 1;
			break;
		default:
			break;
		}
	}

	return nResult;
}

/*====================================================================================
*                                                                                    
* Subroutine  : ID_State()
*                                                                                    
* Parameters  :	bAddr:	装置地址
*			bState:	装置状态 0 投入 1退出
*               
*                                                                                    
* Called from : TcpHeart()
* 
* Description : 打包装置状态上送信息,存入m_SendList队列中
* 
* Return	  : 
*               
*                                             
* Modification: 
*				 2004-07-29: 
*                                                                                     
*====================================================================================*/
void CIEC104::ID_State(BYTE bAddr, BYTE bState)
{
	SYSTEMTIME		systime;		//时间结构体
	DATA_STR		DataInfo;		//数据信息格式

	memset(&DataInfo, 0x00, sizeof(DATA_STR));
	GetLocalTime(&systime);

	DataInfo.ApduHead.bStartCode =  0x68;
	DataInfo.ApduHead.bApduLength = 0x15;
	DataInfo.ApduHead.bControlCode1 = m_wSendCount % 0x100;
	DataInfo.ApduHead.bControlCode2 = m_wSendCount / 0x100;
	DataInfo.ApduHead.bControlCode3 = m_wRevCount % 0x100;
	DataInfo.ApduHead.bControlCode4 = m_wRevCount / 0x100;

	DataInfo.AsduHead.bAsduType =  0x1e;
	DataInfo.AsduHead.bAsduVsq = 0x01;
	DataInfo.AsduHead.nAsduCot = 0x0003;
	DataInfo.AsduHead.nAsduComAddr = bAddr*0x100;
	DataInfo.AsduHead.bAsduInf = 0xc0;
	if (!DataInfo.bDataVec.empty())
	{
		DataInfo.bDataVec.clear();
	}
	DataInfo.bDataVec.push_back(0);//inf+1
	DataInfo.bDataVec.push_back(0);//inf+2
	DataInfo.bDataVec.push_back(bState);
	DataInfo.bDataVec.push_back(systime.wMilliseconds % 1000);
	DataInfo.bDataVec.push_back(systime.wMilliseconds / 1000);
	DataInfo.bDataVec.push_back(systime.wMinute & 0x3f);
	DataInfo.bDataVec.push_back(systime.wHour & 0x1f);
	DataInfo.bDataVec.push_back(systime.wDay & 0x1f);
	DataInfo.bDataVec.push_back(systime.wMonth & 0x1f);
	DataInfo.bDataVec.push_back(systime.wYear % 100);

	m_SendList.push_back(DataInfo);
	DataInfo.bDataVec.clear();

	return;
}

/*====================================================================================
*                                                                                    
* Subroutine  : ReadYXInf104()
*                                                                                    
* Parameters  :	
*			
*               
*                                                                                    
* Called from : CIEC104()
* 
* Description : 读取103遥信信息表
* 
* Return	  : 
*               
*                                             
* Modification: 
*				 2004-07-29: 
*                                                                                     
*====================================================================================*/
int CIEC104::ReadYXInf104()
{
	FILE *fp;
	char Temp_buf[255];
	int bNumber = 0;
	int bResult = 1;

	fp=fopen("yx104.txt","r");
	if(fp!=NULL)
	{
		char* str=fgets(Temp_buf,80,fp);
		if (str==0) 
		{
			bResult = 0;
			return bResult;
		}
		sscanf(str,"%d\n",&bNumber);

		for (int i=0; i<bNumber; i++)
		{
			fscanf(fp, "%d %d\n", &m_bSector[i], &m_bYXInfBuf[i]);	
		}
		fclose(fp);
	}
	else
	{
		bResult = 0;
	}
	return bResult;
}

/*====================================================================================
*                                                                                    
* Subroutine  : ReadSOEInf104()
*                                                                                    
* Parameters  :	
*			
*               
*                                                                                    
* Called from : PutSendList()
* 
* Description : 读取103遥信信息表
* 
* Return	  : 
*               
*                                             
* Modification: 
*				 2004-07-29: 
*                                                                                     
*====================================================================================*/
int CIEC104::ReadSOEInf104(int pot)
{
	FILE *fp;
	char Temp_buf[255];
	int bNumber = 0;
	int pot104 = 0;
	int potCDT = 0;

	fp=fopen("soe104.txt","r");
	if(fp!=NULL)
	{
		char* str=fgets(Temp_buf,80,fp);
		if (str==0) 
		{
			pot104 = 0;
			return pot104;
		}
		sscanf(str,"%d\n",&bNumber);

		for (int i=0; i<bNumber; i++)
		{
			fscanf(fp, "%d %d\n", &potCDT, &pot104);
			if (pot == potCDT) break;
		}
		fclose(fp);
	}
	else
	{
		pot104 = 0;
	}
	return pot104;
}

/*====================================================================================
*                                                                                    
* Subroutine  : ReadYXInfCDT()
*                                                                                    
* Parameters  :	
*			
*               
*                                                                                    
* Called from : CIEC104()
* 
* Description : 读取CDT遥信信息
* 
* Return	  : CDT信息值
*               
*                                             
* Modification: 
*				 2004-07-29: 
*                                                                                     
*====================================================================================*/
int CIEC104::ReadYXInfCDT(BYTE pot)
{
	int nResult = 0;
	int i = 0;
	int size = 0;

	size = sizeof(m_bYXInfBuf)/sizeof(BYTE);
	for(i=0; i<size; i++)
	{
		if (m_bYXInfBuf[i] == pot)
		{
			nResult = i;
			break;
		}
	}
	return nResult;
}

⌨️ 快捷键说明

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