|
Is there some child control that you're expecting to send WM_COMMAND notifications to your CInsertEdit? If not, then it's certainly not going to get called
*edit* Fixed speling
Mark Salsbery
Microsoft MVP - Visual C++
|
|
|
|
|
Mark Salsbery wrote: Is there some child control that you're expecting to send WM_COMMAND notifications to your CInsertEdit?
Of course
Well, if you think this way.....
there is more than one child control,
I didn't show them in example that is all.
In fact, The problem I am facing is not in the main window.
I am facing from child window. The Child window class is CInsertEdit. Its being created in another window(Main Application Window).
If it was simple Non MFC Application it was not a big deal for me. But I am confused with MFC
modified on Sunday, June 26, 2011 6:37 PM
|
|
|
|
|
MFC does a lot of custom processing of command messages. Depending on the type of controls generating the WM_COMMAND messages, you may need to use a more specific message map macro, for example ON_BN_CLICKED for button clicks.
Mark Salsbery
Microsoft MVP - Visual C++
|
|
|
|
|
I wish I can upload all code.
But I cannot,
First of all even though it is an MFC Application, but I didn't create it with application wizard. I am developing this application by hard coding. So, there is not many Message is being handled. There is few Message is already being handled by custom class window. But It is not processing WM_COMMAND or for MFC ON_COMMAND. Shall I have to do anything special on the mother window so that WM_COMMAND get transferred to child window? or from anywhere Shall I have to assign or define equivalent function of TranslateMessage or DispatchMessage??
|
|
|
|
|
Mark Salsbery wrote: Fixed speling
... and introduced a new 'spelling'
|
|
|
|
|
Here is the situation..
I wanted to do something like this
class B
{
private:
A *a;
public:
B(A *ta)
{
a=ta;
}
};
class A
{
int a;
B *b;
public:
A()
{
b=new B(this);
}
};
But it Seems Its not possible... or may I am missing any point...
Anyway, What I am trying to achieve is
I have Main Window class
class CInsertEdit:public CWnd
{
.....
}
class MainWnd:public CWnd
{
CInsertEdit *m_insertEdit;
public:
MainWnd()
{
Create(NULL,L"/\/\/\/\/\/");
.....
Check=m_pInsertEdit->Create(this,CRect(160,0,500,500), 1, WS_CHILD|WS_VISIBLE|WS_BORDER|WS_TABSTOP);
}
int ReEditTreeContol()
{
......
}
protected:
}
What I want is Call the ReEditTreeContol function after Hitting Save Button which is defined and created in CInsertEdit.
I cannot define a pointer in CInsertEdit class. What Can be done?
|
|
|
|
|
This looks more of a design issue. Why do you need a save button inside an edit class? It would be more sensible for the edit class only to be concerned with editing functions. Saving of your data should be done in your main window, which can get a pointer to the data to be saved from the edit class. If you have this sort of cross dependency in your classes then you need to re-think what each class's purpose is.
The best things in life are not things.
|
|
|
|
|
Hey,
Thank you for your reply.
In fact,
Its a set of Edit Control.
So I created a "CLASS"
That contains all required information
The design pattern is like this
From the Tree Control View User can select "New customer" option(on right mouse button a menu get popped up) or "Edit". In both case It will create the the Custom class. In the Custom class it has 4 edit control, one calender control, one combobox, 6 Static control and two buttons.
After Pressing the Save button first data will be saved to database(postgresql) and then it will send a message(now i am planning) (Custom Message) to Main Window. Then Main window will call the function that will recreate the treeview control. If i could create a variable of
class MainWindow it would not be a problem. anyway, i wish you can tell me a better solution
|
|
|
|
|
I still think your design is wrong, you are recursing between your classes, so you have MainWindow calls Edit calls MainWindow . That is just a recipe for disaster, or at the very least for headaches.
The best things in life are not things.
|
|
|
|
|
Its Not Recursion.
Even If I create the second object thousand time, i will only point the first object. it will not create.
Every time the design is like this...
--------------------------------------------
|....Main.Window...........................|
|...------------------------------------...|
|...|......Child.Window................|...|
|...|..................................|...|.....Child window is just holding mian windows pointer
|...------------------------------------...|
|..........................................|
--------------------------------------------
Everything would go wrong if I do this.
--------------------------------------------
|....Main.Window...........................|
|...------------------------------------...|
|...|......Child.Window................|...|
|...|...----------------------------...|...|
|...|...|..Main.Window.Again.......|...|...|
|...|...|..........................|...|...|
|...|...----------------------------...|...|
|...|..................................|...|
|...|..................................|...|
|...------------------------------------...|
|..........................................|
--------------------------------------------
|
|
|
|
|
Have you tried with a forward declaration?
class A; class B
{
private:
A *a;
public:
B(A *ta)
{
a=ta;
}
};
class A
{
int a;
B *b;
public:
A()
{
b=new B(this);
}
};
|
|
|
|
|
Wow,
It solved the problem
Here what i did
file: A.h
class B;
class A
{
int a;
B *b;
public:
A();
};
file A.cpp
#include "A.h"
#inlcude "B.h"
A::A()
{
{
b=new B(this);
}
}
file: B.h
class A;
class B
{
private:
A *a;
public:
B(A *ta)
};
file: B.h
#include "A.h"
#include "B.h"
B:B()
{
a=ta;
}
|
|
|
|
|
What you need is a 'Callback' mechanism, i. e. a way to tell your main window that something changed. The main point here is that whoever noticed or caused the change should not decide what to do about it - in this case call the ReEditTreeControl function.
You can implement a callback mechanism like this:
class IDocumentStateCallback {
public:
virtual void OnDocumentChanged()=0;
}
class MainWnd : public CWnd, IDocumentStateCallback {
private:
void OnDocumentChanged();
};
void MainWnd::OnDocumentChanged() {
ReEditTreeControl();
}
class CInsertEdit: public CWnd {
class IDocumentStateCallback* parent;
void OnSave();
};
#include "IDocumentStateCallback.h"
#include "InsertEdit.h"
void CInsertEdit::Create(CWnd* p, ) {
parent = dynamic_cast<IDocumentStateCallback*>(p);
}
void CInsertEdit::OnSave() {
p->OnDocumentChanged();
}
As you can see the callback mechanism prevents the cyclic dependency, since you now only refer to the interface class rather than the main window class. You can also easily add more kinds of state changes and implement the reaction to each change inside your main window class, rather than in any of the other dependent classes.
|
|
|
|
|
Hello Everyone. I'm new here to both codeproject.com and VC++. I'm running VC++ 6 on an XP system. I happen to own a version of c++ 6 so I installed it on my severely limited resource machine. My issue in my code is with SetTimer and the way the system processes the time expired notification. I think I have figured out through trial and lots of error that when the time has expired a message enters the message queue and the code gets to process it when Windows says so. Initially, I was under the impression that SetTimer was giving me a "code interrupt" kind of service when the time expired. I set up this WHILE(Time_Out_Flag == FALSE){} kinda thing in one particular scope and waited patiently for the OnTimer process to set the Time_Out_Flag to TRUE to escape from the WHILE loop--An event that ultimately would never happen (Ctl+Alt+Del got me control again).
My question is... Is there some way to poll a SetTimer event for timer expiry within my WHILE loop?
Thanks in advance,
John
|
|
|
|
|
You cannot use SetTimer for your purpose.
You must use the CreateWaitableTimer and SetWaitableTimer functions.
You can then poll the timer using the WaitForSingleObject function by specifying a timeout value.
|
|
|
|
|
Thank you. I'll better research on how to implement that for my purpose.
|
|
|
|
|
Member 8012013 wrote: I happen to own a version of c++ 6
I would suggest you dump it as soon as possible, and get a copy of Visual C++ Express[^]. It's free and contains support for the latest levels of C++. You can also look at the other Express products (C#, WebDeveloper) which may be of interest.
The best things in life are not things.
|
|
|
|
|
I'm sure I would benefit greatly getting the latest free download version from Microsoft, but I'm also of the impression that with the whole .Net dependencies of the newer versions, that it would consume more computer resources than ver 6. Is this true? I started to go that path then backed out due to my limited machine that I'm working with.
|
|
|
|
|
You're probably correct, but I have no idea how 'limited' your system is. It's just that using such an old development system you may have problems that have been solved in later versions. Why not give the Express version a try, you can always uninstall it if it does not work well. And remember that C++ is not dependent on .NET.
The best things in life are not things.
|
|
|
|
|
Member 8012013 wrote: ...but I'm also of the impression that with the whole .Net dependencies of the newer versions...
At first glance, I do not see .NET as one of the requirements.
http://download.microsoft.com/download/9/a/e/9ae0f6cc-7032-408e-9ca7-989f9e4af4ec/VS2008ExpressReadme.htm#System Requirements
Upon further inspection, it appears that some version of .NET does get installed. Whether it does so automatically or prompts, I do not know.
"One man's wage rise is another man's price increase." - Harold Wilson
"Fireproof doesn't mean the fire will never come. It means when the fire comes that you will be able to withstand it." - Michael Simmons
"Some people are making such thorough preparation for rainy days that they aren't enjoying today's sunshine." - William Feather
modified on Monday, June 27, 2011 11:01 AM
|
|
|
|
|
Wow! You're right DC. I don't see it listed there either. But I'm pretty sure that when installing the executable, at some point, it begins the installation of .net without user consent. Maybe I need to look at that again.
|
|
|
|
|
Member 8012013 wrote: I think I have figured out through trial and lots of error that when the time has expired a message enters the message queue and the code gets to process it when Windows says so. Initially, I was under the impression that SetTimer was giving me a "code interrupt" kind of service when the time expired.
Yup, that's basically the way that this kind of timer works.
I set up this WHILE(Time_Out_Flag == FALSE){} kinda thing in one particular scope and waited patiently for the OnTimer process to set the Time_Out_Flag to TRUE to escape from the WHILE loop--An event that ultimately would never happen (Ctl+Alt+Del got me control again).
Nooooo!
That's not the way to handle this kind of event at all. When you use the SetTimer function, it will cause windows to send your program a WM_TIMER message with wParam = the id you assigned the timer at creation time. Here's[^] a quick sample of use.
|
|
|
|
|
Surprisingly, I had working code using SetTimer before I even knew how SetTimer was getting treated in the background. It was for a different function than what I was seeking help here for, so I'm still using it. I did my research and figured out how to use CreateWaitableTimer and most all that goes with it (Thank you _Superman_) and now I can poll for a timer event. I'm still unclear about one thing. I don't see any method to "Kill" the waitable version like with SetTimer. Is this ok? Do I still have housekeeping to do? The code is functioning after all.
|
|
|
|
|
Just had a quick check on msdn, it seems that there are two ways for one of these waitable timers to be eliminated.
1) Call CloseHandle on the handle to it. It's destroyed when the last handle to it has been closed.
2) Windows will automatically issue CloseHandle when the process terminates.
So, to be quick'n'dirty - nope. Nothing further to be done(windows will do it for you). To be thorough - yes, you should. It's never nice leaving your mess for somebody else to clean up...
|
|
|
|
|
I am trying with tcp sockets. I have one confusion that suppose I open a port (localhost:9200) and if i use that port for reading and writing both then how the same port can be used for that. Will the data collide if I am trying to write on a port and somebody is sending data on that port?
|
|
|
|