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

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

?? server.c

?? VC++語言中級教材,講授網絡編程中語言的運用技術
?? 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發(fā)送區(qū)域顯示位圖
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)
	{
		//為每個網格得到區(qū)域顯示
		fSend = GetRegionDisplay(hWnd);
		// 計算需要發(fā)送的變化的顯示區(qū)域的數(shù)目
		if (fSend)
			iUpdates++;
		// 移動到下一個節(jié)點
		pGdiNode = pGdiNode->pNext;
	}

	// 發(fā)送到客戶端需要更新的顯示區(qū)域的數(shù)目
	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)
		{
			// 如果桌面發(fā)生了變化,則發(fā)送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);
					// 生成霍夫曼字節(jié)樹字典
					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 (;;)
					{
						// 生成霍夫曼字節(jié)樹字典
						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);
					// 生成霍夫曼字節(jié)樹的字典
					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);
				// 發(fā)送控制消息
				iSent = Transmit(MySocket,szMessage,strlen(szMessage));

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

				// 發(fā)送壓縮的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;
}

//傳輸數(shù)據(jù)到客戶端
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];

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

	// 初始化重疊發(fā)送的結構
	ZeroMemory(&olSend, sizeof(WSAOVERLAPPED));
	// 為發(fā)送重疊結構創(chuàng)建一個信號時間
	olSend.hEvent= gheventOlSock;
	buffSend.len = dwLength;
	buffSend.buf = pData;
	// 持續(xù)發(fā)送,直到dwSendLen個字節(jié)被發(fā)送完成
	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標志的協(xié)議和協(xié)議鏈
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;

	// 決定需要的緩沖區(qū)大小
	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++;
			// 拷貝協(xié)議到調用者的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一区二区三区免费野_久草精品视频
欧美午夜影院一区| 精品入口麻豆88视频| 美女一区二区久久| 亚洲欧美日韩久久| 26uuu欧美| 欧美一区二区三区四区高清| 99国产精品久| 国产乱对白刺激视频不卡| 香蕉影视欧美成人| 亚洲精品国产一区二区三区四区在线| 精品国偷自产国产一区| 欧美激情一区二区三区不卡| 日韩一区二区三区电影| 一本色道亚洲精品aⅴ| 国产一区在线看| 麻豆精品精品国产自在97香蕉| 一区二区不卡在线播放| 国产精品久久久久影院色老大| 欧美一级午夜免费电影| 欧美三级电影网| 色偷偷久久人人79超碰人人澡| 国产毛片精品一区| 激情综合色综合久久| 日韩福利视频导航| 亚洲成人午夜电影| 洋洋成人永久网站入口| 国产精品久久久久久久久搜平片| 久久久五月婷婷| 精品av久久707| 久久久噜噜噜久久人人看 | 国产乱码字幕精品高清av| 婷婷中文字幕综合| 亚洲国产色一区| 亚洲午夜在线观看视频在线| 一区二区三区四区av| 一区二区三区电影在线播| 成人欧美一区二区三区| 亚洲欧美在线高清| 国产精品二三区| 亚洲麻豆国产自偷在线| 一区二区国产盗摄色噜噜| 一区二区三区精品久久久| 亚洲美女一区二区三区| 一区二区三区不卡视频在线观看| 亚洲激情校园春色| 亚洲va欧美va人人爽午夜| 日韩激情在线观看| 精品一二三四区| 国产精品1区2区3区在线观看| 国产精品一区在线| 国产精品77777竹菊影视小说| 国产91高潮流白浆在线麻豆 | 欧美日韩在线不卡| 51午夜精品国产| 精品久久人人做人人爽| 国产日韩欧美一区二区三区乱码| 国产欧美一区视频| 18欧美乱大交hd1984| 亚洲电影一级片| 捆绑变态av一区二区三区| 国产精品一二一区| 99久免费精品视频在线观看| 日本高清不卡aⅴ免费网站| 欧美久久一区二区| 精品不卡在线视频| 一区在线观看免费| 香蕉成人伊视频在线观看| 美女网站色91| 99久久er热在这里只有精品15| 在线亚洲一区二区| 日韩三级高清在线| 中文字幕日韩av资源站| 舔着乳尖日韩一区| 国产盗摄视频一区二区三区| 91蜜桃网址入口| 亚洲美女在线国产| 视频一区视频二区在线观看| 国产一区二区三区美女| 在线观看视频一区二区欧美日韩| 日韩一区二区免费高清| 中文字幕精品在线不卡| 午夜伦欧美伦电影理论片| 国产毛片精品一区| 欧美日韩在线观看一区二区 | 亚洲综合色丁香婷婷六月图片| 美女mm1313爽爽久久久蜜臀| 成人av动漫在线| 91精品久久久久久久久99蜜臂| 欧美国产精品中文字幕| 日本伊人午夜精品| 色综合中文字幕国产 | 岛国一区二区三区| 欧美一区二区福利视频| 亚洲视频一区二区在线| 久久精品国产99| 欧洲精品在线观看| 国产日韩欧美精品一区| 日本午夜精品一区二区三区电影| 99久久婷婷国产精品综合| 26uuu精品一区二区| 亚洲成av人片在线| 99riav久久精品riav| 日韩视频123| 亚洲成人一二三| 一道本成人在线| 久久精品人人做人人综合 | 亚洲视频中文字幕| 国产乱子伦视频一区二区三区| 精品污污网站免费看| 亚洲日本va在线观看| 国产91精品一区二区麻豆亚洲| 5566中文字幕一区二区电影| 一区二区三区美女| 91免费精品国自产拍在线不卡| 久久精品视频在线看| 韩国精品久久久| 欧美va天堂va视频va在线| 日韩中文字幕麻豆| 欧美日韩视频一区二区| 亚洲综合视频网| 色狠狠一区二区| 一区二区三区在线观看视频| 99久久精品国产毛片| 国产精品成人免费精品自在线观看| 寂寞少妇一区二区三区| 日韩女优毛片在线| 日日夜夜精品视频天天综合网| 欧美在线|欧美| 亚洲综合免费观看高清完整版在线 | 亚洲欧洲成人av每日更新| 成人综合日日夜夜| 日本一二三不卡| 成人一级视频在线观看| 欧美国产丝袜视频| 欧美精品一级二级三级| 午夜欧美电影在线观看| 在线不卡的av| 免费高清不卡av| 日韩视频免费观看高清完整版在线观看 | 青青草一区二区三区| 日韩欧美一区二区免费| 麻豆91在线播放免费| 26uuuu精品一区二区| 国产福利一区二区三区视频| 中文字幕不卡在线观看| www.欧美日韩| 夜夜嗨av一区二区三区中文字幕| 在线欧美日韩国产| 同产精品九九九| 欧美大片拔萝卜| 国产精品自产自拍| 中文一区在线播放 | 欧美精品一区二区久久久| 国产精品一区二区三区99| 国产精品网友自拍| 色网站国产精品| 青青草精品视频| 亚洲国产精品成人综合色在线婷婷| caoporen国产精品视频| 亚洲一区免费在线观看| 777奇米成人网| 国产成人三级在线观看| 尤物在线观看一区| 日韩欧美色电影| 成人午夜在线播放| 亚洲一区二区三区激情| 精品福利一二区| av一区二区三区黑人| 亚洲国产欧美一区二区三区丁香婷| 日韩一区二区在线看片| 丰满白嫩尤物一区二区| 一区二区高清免费观看影视大全| 欧美美女黄视频| 成人动漫av在线| 日韩黄色免费电影| 国产欧美精品一区二区色综合 | 亚洲美腿欧美偷拍| 欧美大片在线观看一区| 91老师国产黑色丝袜在线| 免费成人美女在线观看.| 国产精品进线69影院| 欧美日韩免费视频| 成人性生交大合| 日韩精品免费视频人成| 亚洲国产精品精华液ab| 在线电影一区二区三区| 成人免费观看av| 全国精品久久少妇| 亚洲欧美偷拍卡通变态| 欧美电影免费观看高清完整版| 色国产综合视频| 国产精品中文字幕一区二区三区| 夜夜亚洲天天久久| 中文字幕精品综合| 日韩欧美二区三区| 欧美中文字幕一区二区三区| 成人在线视频首页| 蜜臀精品久久久久久蜜臀| 樱花影视一区二区| 国产精品色婷婷|