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

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

?? server.c

?? 《Visual C++網絡通信編程實用案例精選》配套源碼
?? C
?? 第 1 頁 / 共 3 頁
字號:

	// 建立屏幕的高度
	memset(szMessage,'\0',sizeof(szMessage));
	sprintf(szMessage,"%d",iHeight);
	iSent = Transmit(MySocket,szMessage,strlen(szMessage));

	// 接收確認
	memset(szMessage,'\0',sizeof(szMessage));
	iRecv = recv(MySocket,szMessage,81,0);
	szMessage[iRecv] = '\0';
}

// 通過socket發送區域顯示位圖
int SendRegionDisplay(HWND hWnd,SOCKET MySocket)
{
	char	szMessage[81];
	DWORD	iSent,iRecv;
	int		fSend = FALSE;
	int		iUpdates;
	WORD	wTreeSize;
	DWORD	dwByteTree[768];
	DWORD	dwCodes[514];
	DWORD	dwCompLen,dwLastCompLen;
	BOOL	fTransmit;
	char	*pTempDIB;
	DWORD	dwMinCompress;

	// 指向GDI鏈表的起始位
	iUpdates = 0;
	pGdiNode = GdiStart.pNext;
	while (pGdiNode)
	{
		//為每個網格得到區域顯示
		fSend = GetRegionDisplay(hWnd);
		// 計算需要發送的變化的顯示區域的數目
		if (fSend)
			iUpdates++;
		// 移動到下一個節點
		pGdiNode = pGdiNode->pNext;
	}

	// 發送到客戶端需要更新的顯示區域的數目
	memset(szMessage,'\0',sizeof(szMessage));
	sprintf(szMessage,"%d",iUpdates);
	iSent = Transmit(MySocket,szMessage,strlen(szMessage));
	// 接收確認
	memset(szMessage,'\0',sizeof(szMessage));
	iRecv = recv(MySocket,szMessage,81,0);
	szMessage[iRecv] = '\0';

	if (iUpdates > 0)
	{
		// 指向GDI鏈表的起始位
		pGdiNode = GdiStart.pNext;
		while (pGdiNode)
		{
			// 如果桌面發生了變化,則發送DIB
			if (pGdiNode->Gdi.fChange)
			{
				int		iCompressions = 1;
				//無壓縮
				if (iCompressionLevel == 0) 
				{
					pGdiNode->Gdi.pDIBCompress = (char *)malloc(pGdiNode->Gdi.dwCompress);
					memblast(pGdiNode->Gdi.pDIBCompress,pGdiNode->Gdi.pDIBChange,pGdiNode->Gdi.dwCompress);
					dwSendLen = pGdiNode->Gdi.dwCompress;
				}
				if (iCompressionLevel == 10) // 單遍霍夫曼編碼壓縮
				{
					pGdiNode->Gdi.pDIBCompress = (char *)malloc(pGdiNode->Gdi.dwCompress + 1536);
					// 生成霍夫曼字節樹字典
					wTreeSize = HuffmanDictionary(pGdiNode->Gdi.pDIBChange,pGdiNode->Gdi.dwCompress,&dwByteTree[0],&dwCodes[0]);
					// 使用霍夫曼壓縮方法壓縮圖片
					dwSendLen = HuffmanCompress(pGdiNode->Gdi.pDIBChange,pGdiNode->Gdi.dwCompress,wTreeSize,&dwByteTree[0],&dwCodes[0],pGdiNode->Gdi.pDIBCompress);
				}
				else if (iCompressionLevel == 11) // 多遍霍夫曼壓縮編碼
				{
					dwMinCompress = pGdiNode->Gdi.dwCompress + 1536;
					pGdiNode->Gdi.pDIBCompress = (char *)malloc(dwMinCompress);
					pTempDIB = (char *)malloc(pGdiNode->Gdi.dwCompress);
					memblast(pTempDIB,pGdiNode->Gdi.pDIBChange,pGdiNode->Gdi.dwCompress);
					iCompressions = 0;
					dwCompLen = pGdiNode->Gdi.dwCompress;
					dwLastCompLen = dwCompLen;
					for (;;)
					{
						// 生成霍夫曼字節樹字典
						wTreeSize = HuffmanDictionary(pTempDIB,pGdiNode->Gdi.dwCompress,&dwByteTree[0],&dwCodes[0]);
						// 計算壓縮長度
						dwCompLen = HuffmanCountCompress(pTempDIB,dwCompLen,wTreeSize,&dwCodes[0]);
						if (dwCompLen < dwMinCompress)
						{
							dwSendLen = HuffmanCompress(pTempDIB,dwLastCompLen,wTreeSize,&dwByteTree[0],&dwCodes[0],pGdiNode->Gdi.pDIBCompress);
							memblast(pTempDIB,pGdiNode->Gdi.pDIBCompress,dwSendLen);
							dwMinCompress = dwSendLen;
							dwLastCompLen = dwCompLen;
							iCompressions++;
						}
						else
							break;
					}
					free(pTempDIB);
				}
				else if (iCompressionLevel == 12) // Run Length編碼
				{
					//為最壞的情況分配壓縮空間
					pGdiNode->Gdi.pDIBCompress = (char *)malloc(pGdiNode->Gdi.dwCompress * 3 + 4);
					// Run Length編碼圖象
					dwSendLen = RunLengthEncode(pGdiNode->Gdi.pDIBChange,pGdiNode->Gdi.dwCompress,pGdiNode->Gdi.pDIBCompress);
				}
				else if (iCompressionLevel == 13) // Run Length&Huffman編碼
				{
					pTempDIB = (char *)malloc(pGdiNode->Gdi.dwCompress * 3 + 4);
					pGdiNode->Gdi.pDIBCompress = (char *)malloc(pGdiNode->Gdi.dwCompress * 3 + 4);
					// Run Length 編碼圖象
					dwCompLen = RunLengthEncode(pGdiNode->Gdi.pDIBChange,pGdiNode->Gdi.dwCompress,pTempDIB);
					// 生成霍夫曼字節樹的字典
					wTreeSize = HuffmanDictionary(pTempDIB,dwCompLen,&dwByteTree[0],&dwCodes[0]);
					// 使用霍夫曼壓縮Run Lenght編碼的圖象
					dwSendLen = HuffmanCompress(pTempDIB,dwCompLen,wTreeSize,&dwByteTree[0],&dwCodes[0],pGdiNode->Gdi.pDIBCompress);
					// 釋放臨時的DIB
					free(pTempDIB);
				}

				// 建立位圖控制消息
				memset(szMessage,'\0',sizeof(szMessage));
				sprintf(szMessage,"%d;%d;%d;%ld;%ld;%ld;",
					iCompressions,
					pGdiNode->Gdi.iGridX,pGdiNode->Gdi.iGridY,
					pGdiNode->Gdi.iStartPos,
					pGdiNode->Gdi.dwCompress,dwSendLen);
				// 發送控制消息
				iSent = Transmit(MySocket,szMessage,strlen(szMessage));

				// 接收確認
				memset(szMessage,'\0',sizeof(szMessage));
				iRecv = recv(MySocket,szMessage,81,0);
				szMessage[iRecv] = '\0';

				// 發送壓縮的DIB
				fTransmit = Transmit(MySocket,pGdiNode->Gdi.pDIBCompress,dwSendLen);
				// 釋放壓縮的DIB
				free(pGdiNode->Gdi.pDIBCompress);
				// 接收確認
				memset(szMessage,'\0',sizeof(szMessage));
				iRecv = recv(MySocket,szMessage,81,0);
				szMessage[iRecv] = '\0';
			}
			pGdiNode = pGdiNode->pNext;
		}
	}
	return iUpdates;
}

//傳輸數據到客戶端
BOOL Transmit(SOCKET MySocket,char *pData,DWORD dwLength)
{
	WSAOVERLAPPED	olSend;
	WSAEVENT	gheventOlSock;
	WSAEVENT	eventArray[2];
	WSABUF		buffSend;
	DWORD		dwRet,dwNumBytes,dwFlags;
	int			nWSAError;
	char		szError[81];

	// 為發送完成創建一個信號事件
	gheventOlSock = WSACreateEvent();
	eventArray[0] = gheventOlSock;

	// 初始化重疊發送的結構
	ZeroMemory(&olSend, sizeof(WSAOVERLAPPED));
	// 為發送重疊結構創建一個信號時間
	olSend.hEvent= gheventOlSock;
	buffSend.len = dwLength;
	buffSend.buf = pData;
	// 持續發送,直到dwSendLen個字節被發送完成
	while (TRUE)
	{
		if ((dwRet = WSASend(MySocket,&buffSend,1,&dwNumBytes,0,&olSend,NULL)) == SOCKET_ERROR)
		{
			nWSAError= WSAGetLastError();
			if (nWSAError != ERROR_IO_PENDING)
			{
				sprintf(szError,"WSASend failed with error %d\n",nWSAError);
				MessageBox(NULL,szError,"Server",MB_OK);
			}
		}
	
		if (WSAWaitForMultipleEvents(1,eventArray,FALSE,WSA_INFINITE,FALSE) == WSA_WAIT_FAILED)
		{
			sprintf(szError,"WSAWaitForMultipleEvents failed %d\n", WSAGetLastError());
			MessageBox(NULL,szError,"Server",MB_OK);
		} 
		// 重置gheventOlSock
		WSAResetEvent(eventArray[0]);
		if (WSAGetOverlappedResult(MySocket,&olSend,&dwNumBytes,FALSE,&dwFlags) == FALSE)
		{
			sprintf(szError,"WSAGetOverlappedResult failed with error %d\n", WSAGetLastError());
			MessageBox(NULL,szError,"Server",MB_OK);
		}
		buffSend.len -= dwNumBytes;
		if (buffSend.len == 0) 
			break;
		else 
			buffSend.buf += dwNumBytes;
	}

	// 關閉信號事件
	WSACloseEvent(gheventOlSock);
	return TRUE;
}

//返回本機安裝的所有的有XP1_GUARANTEED_DELIVERY and XP1_GUARANTEED_ORDER標志的協議和協議鏈
int SelectProtocols(DWORD dwSetFlags,DWORD dwNotSetFlags,LPWSAPROTOCOL_INFO lpProtocolBuffer,LPDWORD lpdwBufferLength,WSAPROTOCOL_INFO *pProtocol)
{
	LPBYTE				pBuf;
	LPWSAPROTOCOL_INFO	pInfo;
	DWORD				dwNeededLen;
	LPWSAPROTOCOL_INFO	pRetInfo;
	DWORD				dwRetLen;
	int					nCount;
	int					nMatchCount;
	int					nRet;

	// 決定需要的緩沖區大小
	dwNeededLen = 0;
	nRet = WSAEnumProtocols(NULL, NULL, &dwNeededLen);
	if (nRet == SOCKET_ERROR)
	{
		if (WSAGetLastError() != WSAENOBUFS)
			return SOCKET_ERROR;
	}
	// 分配大小
	pBuf = malloc(dwNeededLen);
	if (pBuf == NULL)
	{
		WSASetLastError(WSAENOBUFS);
		return SOCKET_ERROR;
	}

	nRet = WSAEnumProtocols(NULL,(LPWSAPROTOCOL_INFO)pBuf,&dwNeededLen);
	if (nRet == SOCKET_ERROR)
	{
		free(pBuf);
		return SOCKET_ERROR;
	}

	#define REJECTSET(f) \
	    ((dwSetFlags & f) && !(pInfo->dwServiceFlags1 & f))
	#define REJECTNOTSET(f) \
	    ((dwNotSetFlags &f) && (pInfo->dwServiceFlags1 & f))
	#define REJECTEDBY(f) (REJECTSET(f) || REJECTNOTSET(f))

	pInfo = (LPWSAPROTOCOL_INFO)pBuf;	
	pRetInfo = lpProtocolBuffer;
	dwRetLen = 0;
	nMatchCount = 0;
	for(nCount = 0; nCount < nRet; nCount++)
	{
		while(1)
		{
			if (REJECTEDBY(XP1_CONNECTIONLESS))
				break;
			if (REJECTEDBY(XP1_GUARANTEED_DELIVERY))
				break;
			if (REJECTEDBY(XP1_GUARANTEED_ORDER))
				break;
			if (REJECTEDBY(XP1_MESSAGE_ORIENTED))
				break;
			if (REJECTEDBY(XP1_PSEUDO_STREAM))
				break;
			if (REJECTEDBY(XP1_GRACEFUL_CLOSE))
				break;
			if (REJECTEDBY(XP1_EXPEDITED_DATA))
				break;
			if (REJECTEDBY(XP1_CONNECT_DATA))
				break;
			if (REJECTEDBY(XP1_DISCONNECT_DATA))
				break;
			if (REJECTEDBY(XP1_SUPPORT_BROADCAST)) 
				break;
			if (REJECTEDBY(XP1_SUPPORT_MULTIPOINT))
				break;
			if (REJECTEDBY(XP1_MULTIPOINT_DATA_PLANE))
				break;
			if (REJECTEDBY(XP1_QOS_SUPPORTED))
				break;
			if (REJECTEDBY(XP1_UNI_SEND))
				break;
			if (REJECTEDBY(XP1_UNI_RECV))
				break;
			if (REJECTEDBY(XP1_IFS_HANDLES))
				break;
			if (REJECTEDBY(XP1_PARTIAL_MESSAGE))
				break;

			dwRetLen += sizeof(WSAPROTOCOL_INFO);

			if (dwRetLen > *lpdwBufferLength)
			{
				WSASetLastError(WSAENOBUFS);
				*lpdwBufferLength = dwNeededLen;
				free(pBuf);
				return SOCKET_ERROR;
			}
			nMatchCount++;
			// 拷貝協議到調用者的buffer里
			memblast(pRetInfo,pInfo,sizeof(WSAPROTOCOL_INFO));
			if (strcmp(pInfo->szProtocol,"MSAFD Tcpip [TCP/IP]") == 0)
				memblast(pProtocol,pInfo,sizeof(WSAPROTOCOL_INFO));
			pRetInfo++;
			break;
		}
		pInfo++;
	}
	free(pBuf);
	*lpdwBufferLength = dwRetLen;
	return(nMatchCount);
}

void memblast(void* dest,void* src,DWORD count)
{
	DWORD	iCount;

	__asm
	{
		MOV		ECX,count
		SHR		ECX,2
		SHL		ECX,2
		MOV		iCount,ECX

		MOV		ESI,src
		MOV		EDI,dest
		MOV		ECX,iCount
		SHR		ECX,2	
		REP		MOVSD	

		MOV		ECX,count
		MOV		EAX,iCount
		SUB		ECX,EAX

		JZ		Exit

		MOV		ESI,src	
		ADD		ESI,EAX	
		MOV		EDI,dest	
		ADD		EDI,EAX		
		REP		MOVSB		
		Exit:
	}
}
/*
int GetLocalHostName(char* sHostName)	//獲得本地計算機名稱
{
	char szHostName[256];
	int nRetCode;
	nRetCode=gethostname(szHostName,sizeof(szHostName));
	if(nRetCode!=0)
	{
		//產生錯誤
		strcpy(sHostName,"沒有取得");
		return GetLastError();
	}
	strcpy(sHostName,szHostName);
	return 0;
}
int GetIpAddress(char *sHostName, BYTE *f0,BYTE *f1,BYTE *f2,BYTE *f3)//獲得本地IP
{
	struct hostent FAR * lpHostEnt=gethostbyname(sHostName);
	if(lpHostEnt==NULL)
	{
		//產生錯誤
		f0=f1=f2=f3=0;
		return GetLastError();
	}
	//獲取IP
	if(lpHostEnt->h_addr_list[0])
	{
		struct in_addr inAddr;
		memmove(&inAddr,lpHostEnt->h_addr_list[0],4);
		*f0=inAddr.S_un.S_un_b.s_b1;
		*f1=inAddr.S_un.S_un_b.s_b2;
		*f2=inAddr.S_un.S_un_b.s_b3;
		*f3=inAddr.S_un.S_un_b.s_b4;
	}
	return 0;
}
*/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99re热视频精品| 精品一二线国产| 久久精品视频一区| 日韩女优av电影| 日韩亚洲欧美在线观看| 欧美理论片在线| 777a∨成人精品桃花网| 欧美在线免费观看亚洲| 欧美日韩亚洲丝袜制服| 欧美人动与zoxxxx乱| 欧美日韩国产综合一区二区| 欧美日韩免费电影| 91精品国产免费久久综合| 日韩欧美三级在线| 久久久国产精华| 亚洲欧洲韩国日本视频| 亚洲在线观看免费| 日韩电影在线看| 国产麻豆精品一区二区| 成人国产精品视频| 在线观看视频91| 精品日韩在线观看| 中文字幕一区二区三区在线播放| 亚洲乱码精品一二三四区日韩在线| 亚洲成a人片在线不卡一二三区| 日韩黄色免费电影| 东方aⅴ免费观看久久av| 97精品久久久久中文字幕| 欧美精品国产精品| 久久久www免费人成精品| 亚洲欧美另类在线| 免费高清在线视频一区·| 丁香啪啪综合成人亚洲小说| 欧美亚一区二区| 国产亚洲精品aa午夜观看| 亚洲与欧洲av电影| 国内成人免费视频| 日韩无一区二区| 国产精品久久久久aaaa樱花| 天天色天天操综合| 99麻豆久久久国产精品免费| 91麻豆精品国产| 国产精品国产三级国产| 男女性色大片免费观看一区二区 | 99综合电影在线视频| 欧美性生交片4| 亚洲国产精品精华液2区45| 亚洲国产精品欧美一二99| 国产麻豆视频精品| 91精品国产美女浴室洗澡无遮挡| 亚洲图片另类小说| 国产一区二区影院| 3d成人动漫网站| 亚洲欧美区自拍先锋| 国产精品1024| 欧美成人三级在线| 亚洲午夜日本在线观看| av不卡一区二区三区| 久久这里只有精品6| 日韩电影在线观看一区| 在线观看一区不卡| 亚洲欧美日韩在线| 成人性生交大合| 国产亚洲一区二区三区| 精品亚洲国内自在自线福利| 在线91免费看| 视频一区二区不卡| 欧美日韩国产首页| 亚洲一二三四久久| 91香蕉视频在线| 亚洲欧洲99久久| 99久久精品国产一区| 国产精品视频一区二区三区不卡| 国产久卡久卡久卡久卡视频精品| 日韩欧美成人激情| 蜜臀av性久久久久蜜臀aⅴ四虎 | 国产激情一区二区三区| 日韩一二三区不卡| 久久99久久久久| 日韩欧美另类在线| 日韩电影在线看| 日韩精品最新网址| 精品伊人久久久久7777人| 国产精品伦理在线| 成人动漫一区二区在线| 中文字幕乱码亚洲精品一区| 高清日韩电视剧大全免费| 国产精品欧美精品| 一本色道久久综合亚洲aⅴ蜜桃| 国产精品久久久爽爽爽麻豆色哟哟 | 欧美在线小视频| 亚洲.国产.中文慕字在线| 91精品国产麻豆国产自产在线| 日本va欧美va欧美va精品| 26uuu亚洲综合色| 国产成人av影院| 亚洲欧美日韩综合aⅴ视频| 欧美日韩中文字幕一区二区| 日本最新不卡在线| 2021久久国产精品不只是精品| 成人黄色电影在线| 亚洲国产成人高清精品| 欧美一区二区成人6969| 国产成人免费在线视频| 亚洲乱码国产乱码精品精可以看| 欧美在线你懂得| 精品一区二区国语对白| 1000精品久久久久久久久| 欧美日韩国产高清一区| 国产一区二区三区视频在线播放| 最新热久久免费视频| 欧美绝品在线观看成人午夜影视| 国产一区二区女| 一级做a爱片久久| 久久综合九色综合欧美98| 色婷婷亚洲精品| 国精产品一区一区三区mba视频| 亚洲三级电影网站| 久久亚区不卡日本| 欧美三级资源在线| 色综合天天综合给合国产| 日本欧美一区二区三区乱码| 日本一区二区动态图| 日韩欧美在线一区二区三区| 91婷婷韩国欧美一区二区| 韩国av一区二区三区在线观看| 亚洲精品乱码久久久久久黑人 | 中文字幕欧美一| 日韩欧美一区中文| 欧美亚一区二区| 成人avav在线| 国产精品91一区二区| 日韩在线卡一卡二| 亚洲精品日日夜夜| 国产精品五月天| 精品国产一二三区| 91精品国产色综合久久久蜜香臀| 91麻豆.com| 99久久久久久99| 成人国产精品免费网站| 国产精选一区二区三区 | 精品蜜桃在线看| 在线电影院国产精品| 欧洲一区在线电影| av亚洲产国偷v产偷v自拍| 国产盗摄一区二区三区| 国产综合久久久久久鬼色| 免费观看91视频大全| 麻豆中文一区二区| 日本成人在线电影网| 日韩精品成人一区二区三区| 一区二区三区久久| 一区二区三区日韩在线观看| 亚洲你懂的在线视频| 亚洲欧美国产77777| 亚洲四区在线观看| 亚洲狼人国产精品| 一区二区理论电影在线观看| 一区二区三区在线视频免费| 尤物视频一区二区| 亚洲资源在线观看| 五月天精品一区二区三区| 日韩精品五月天| 日本美女一区二区三区视频| 捆绑调教一区二区三区| 精彩视频一区二区三区| 国产黄色精品网站| www.爱久久.com| 在线精品视频免费观看| 欧美日韩一本到| 欧美电影免费观看高清完整版在 | 色欲综合视频天天天| 一本大道综合伊人精品热热| 欧美性猛交xxxx黑人交| 欧美群妇大交群中文字幕| 日韩一二三四区| 亚洲国产精品99久久久久久久久| 国产精品蜜臀在线观看| 尤物视频一区二区| 久久精品国产亚洲aⅴ| 国产精品88888| 在线一区二区三区四区| 日韩一区二区免费高清| 中文在线一区二区| 亚洲成人综合视频| 国精产品一区一区三区mba桃花 | 99久久精品国产麻豆演员表| 欧美在线三级电影| 精品国精品自拍自在线| 亚洲三级理论片| 麻豆国产欧美日韩综合精品二区| 丰满白嫩尤物一区二区| 欧美电影一区二区| 国产欧美一区二区精品仙草咪 | 久久久久成人黄色影片| 亚洲激情成人在线| 国产一区二区成人久久免费影院| 91女神在线视频| 337p日本欧洲亚洲大胆精品| 一区二区高清在线|