|
Fine, but we cannot help you unless you explain what is going wrong.
|
|
|
|
|
I did tried with this one...
case WM_SOCKET:
{
int i=256;
BYTE* data = new BYTE[256*256*256];
int packetsize, num;
int newWidth, newHeight;
int recvimgsize=0;
bool bAwaitingImage = false;
switch(WSAGETSELECTEVENT(lParam))
{
case FD_READ:
{
num=recv(Socket, (char*)data, 3, 0);
if(num>0)
{
packetsize = data[1]*256+ data[2];
num=recv(Socket, (char*)(data+3), packetsize-3, 0);
}
if(num>0)
{
switch(data[0])
{
case 2:
newWidth = data[3]*256+data[4];
newHeight = data[5]*256+data[6];
if(newHeight!=cBitmap.bmHeight || newWidth!=cBitmap.bmWidth)
{
cBitmap.bmWidth = newWidth;
cBitmap.bmHeight = newHeight;
RECT r;
GetWindowRect(hWnd, &r);
SetWindowPos(hWnd, NULL, r.left, r.top, cBitmap.bmWidth, cBitmap.bmHeight, 0);
HDC ThisDC = GetDC(hWnd);
DeleteDC(RemoteDC);
RemoteDC = CreateCompatibleDC(ThisDC);
DeleteObject(hbitmap);
hbitmap = CreateCompatibleBitmap(ThisDC,cBitmap.bmWidth ,cBitmap.bmHeight);
SelectObject(RemoteDC, hbitmap);
ReleaseDC(hWnd, ThisDC);
}
break;
case 3:
{
BITMAPINFO bi;
int biSize = sizeof(BITMAPINFO);
memcpy(&bi, data+3, biSize);
SetDIBits(RemoteDC, hbitmap, 0,cBitmap.bmHeight, data+biSize+3, &bi, DIB_RGB_COLORS);
InvalidateRect(hWnd, NULL, false);
break;
}
its a long code ,,,
but i got stuck on when client sends image then it is completely sent but from server side program hangs and stopped working and nothing on server.
I'll be highly thankful if you can help me in this!!
Thanks
|
|
|
|
|
toms from newdelhi wrote: it is completely sent but from server side program hangs Sorry, but there is no way I can guess what may be happening. You need to get with your debugger at both ends and trace where it is getting stuck.
|
|
|
|
|
The Problem it is showing in debugger and as I analyzed is that server is unable to
store the data in a buffer.
The buffer is showing problem.
Thanks!
|
|
|
|
|
toms from newdelhi wrote: The buffer is showing problem. I'm sorry but you really need to learn to give exact details. A statement like this tells us nothing.
|
|
|
|
|
Well, you are starting off from the wrong basis here.
A TCP server (in fact a client and server) is implemented in the kernel (on WIndows as TCPIP.sys) and supports am interface called TDI (on older Windows OSs and called something else on newer ones). TDI transports across the IO manager (Kernel to USer mode), providing sockets in the user mode for applications to use.
So what you need are two apps one that opens a socket and sends a bmp file, and another that waits on a socket and can render that bmp file to the screen.
(You can also not directly display UI stuff from the kernel so the stock TCP kernel driver would never be able to display a bmp)
If you really wanted to implement a user mode TCP server/client module then the question is why, and the problem is how you are going to send IP packets to the network card. And if you wanted to send Ethernet packets to the network card you would need to implement IP in user mode too. And if you wanted to do that you would need to write a network driver for your card with a interface accessible to the IO manager that you could open in user mode to get those Ethernet packets to it. All in all a massive and complex problem, so just use sockets, its what they are made for, and made by a lot of very clever people who understood the network stack and provided it for people like you to use.
==============================
Nothing to say.
|
|
|
|
|
I think you misunderstood OP's question.
|
|
|
|
|
Could be, it was an odd question.
==============================
Nothing to say.
|
|
|
|
|
Sir,
I'm creating a simple TCP server with which I can receive the images and display those on server window.
|
|
|
|
|
But like I said the TCP module is embedded in tcpip.sys in the kernel. Why reinvent the wheel?
You already have sockets that provides a transport across the network usually using TCP over IP so why not use it?
==============================
Nothing to say.
|
|
|
|
|
sir this application is for showing the IPAD on a windows screen.
That's why I'm creating this to do so..
I'll have to receive the data from IPAD and will have to show it on
Window or on a GUI in windows 7.
Thanks!
|
|
|
|
|
So what existing transports are there for data between an IPAD and a PC? DO IPADs support WiFi? Bluetooth? How about a USB connection?
https://www.google.fr/search?client=opera&rls=en&q=IPAD+to+PC+communication&sourceid=opera&ie=utf-8&oe=utf-8&channel=suggest
Lots of ways to skin a cat without reinventing the wheel.
==============================
Nothing to say.
|
|
|
|
|
|
Respected Andy Sir,
I've studied your applications written on codeproject
and discussed to my senior but he refuses to use it in a long way.
The thing is only to receive the images and show them without saving,,, its complete thing like you have done..
Can you help me in this??
|
|
|
|
|
Tell your boss I'm available, by a short term contract, to write the application for him. I could produce this application in a short amount of time and to his specifications.
|
|
|
|
|
Hi,
I am writting a OLE app that I want to be MFC based towards that end
I think I need two things
1) A Main Thread CWinApp
2) A main window "m_pMainWnd"
My question is can the main window be a modeless dialog box or does it have
to be CFrameWnd
Thanks
|
|
|
|
|
What do you mean by modeless?
In all MFC dialog based apps, the main dialog acts just like a modeless child dialog.
|
|
|
|
|
Something Along the lines of dlg.Create and then m_pMainWnd = &dlg;
|
|
|
|
|
It could, but exactly what advantage does it offer? A modal dialog as main window is a much better choice.
|
|
|
|
|
youre the MFC experts but doesn't a modal need a user respose yes/no when you do a dlg.domodal that thread stops until the user responds
I was wondering the automation examples (using MFC) had a modal dialogbox for the mainwindow ?
|
|
|
|
|
ForNow wrote: doesn't a modal need a user respose yes/no when you do a dlg.domodal that thread stops until the user responds True, but if it's the main window there is no other thread to worry about. You can do lots of actions within the dialog box while it is on the screen. Maybe you should explain exactly what problem you are trying to solve, rather than deciding on the window type before you know what you want to do with it.
|
|
|
|
|
I copied the code from msdn example on automation which had a main thread and a modal
dialog box for a main window I just changed the modal to modeless "dlg.create"
I had a problem on the create so created a CFrameWnd as the main window
anyway I got bigger problems I cann't get GetIDsOfNames to work
I'll post the particualrs on the "COM" forum
Thanks
|
|
|
|
|
The modal dialog is the main window in this sort of application. However, I'm still far from clear what you are really trying to do.
|
|
|
|
|
When you create the project choose Dialog Project in the options, this will give you a dialog applicaiton which I think is what you want.
==============================
Nothing to say.
|
|
|
|
|