|
I have three suggestion/comments:
1.) You said quote: "Later I create a modeless Dialog in the childprocess for which I would like the to get the HWND handle."
Doesn't matter which create method you use you get the handle back right then ... so why don't you hold it??????
2.) Like others I wonder why you are using MFC at all which will be problematic why would you not just use the WIN32 API.
3.) If GetWindow(MainFrame,GW_CHILD) and EnumChildWindows are returning false the your created window isn't parented
to the window at all. It's most likely parented to the desktop and again go back to number 1 above show us the how
you created the modeless dialog and check you gave it a parent.
The key point here is a show use the lines of code around the modeless dialog creation call.
In vino veritas
|
|
|
|
|
I did use GetWindow and got NULL. I was able to get Window Handle by doing a SendMessage to the other app as the return Value is From the other Window App (not Windows like PostMessage) I returned the dialog window in LRESULT
Thanks
|
|
|
|
|
Well,
Using MFC, in a multithreaded environment, communication via SendMessage(...) is an essential.
Trying to sculpt WDK Messages for my own purpose. Use WM_USER+x, Major Crash,turned out, WM_USER+x was already used by MFC42 in a control I used in my Dialog!
has Anyone any idea what the range of messages are used or reserved by MFC in general, and what the Real Message range is, available to MFC developers.
++"#define WM_MFC_USERS 0xABXD1234
Or, something of that kind in some header somewhere. If this is the case, please let me know the Name and the value of the macro is.
Regards
Bram van Kampen
|
|
|
|
|
WM_USER is obsolete. Use WM_APP instead. Or better use registered messages.
A good description about this topic can be found in the CodeProject article Message Management[^].
|
|
|
|
|
WM_USER+x should only ever be used inside a single application, as it is free to use by everyone. Using it in a driver is almost bound to cause tears before bedtime.
[edit]
WM_USER (Windows)[^] and WM_APP (Windows)[^] list the rules.
[/edit]
|
|
|
|
|
Thanks,
I am aware of RegisterMessage(...) etc, but have always considered it as a canon to shoot a fly. It may be the better Idea for future, particularly after the nightmare I encounter now. Your idea of attaching a GUID is particularly fetching.
WM_USER +X, It worked for me many a time in the past. I can now see the flaws
Thanks,
Bram.
Bram van Kampen
|
|
|
|
|
|
It looks like a reply to my answer posted to yours inadvertently.
|
|
|
|
|
I don't know what Bram is smoking these days, but I think he should cut down.
|
|
|
|
|
Hi,
Good to talk again.
My header files do not provide a macro for WM_APP. Maybe you could let me know for future reference, if it is a single value. Also AOP has advised me to Register a Windows Message. Probably the way forward for the Future.
Thanks for your contribution.
Bram.
Bram van Kampen
|
|
|
|
|
|
Is a crtical section a way of ensuring the your code runs synchrounsly as window message processing seems to take precedence in code execution
|
|
|
|
|
It ensures only one thread can go through that code path: see Critical Section Objects (Windows)[^].
ForNow wrote: window message processing seems to take precedence Not sure what you mean by that.
|
|
|
|
|
In Short, No!
Critical Sections are Synchronisation Objects, It is of use only if your project is multi threaded,ie Has More than One thread running in the One Program. Each thread of your program, will wait in front of a CriticalSection where you try to Enter It, until all other threads leave it. It is a communal comunication deal between threads in a program. One thread of a program will not allow another thread to run, until the section is released. Other programs can switch thread in the mean time.
The Nature and context of the question worries me! You seem to have to learn an awfull lot more before you are ready to discus critical sections
Bram van Kampen
|
|
|
|
|
No,
It is NOT, and I explained that already!
However, I also answered your other question, in quite a lot of detail. Before you can attempt to learn MFC Multi Threaded Programming, you will need to learn basic MFC Programming, and elements of the Windows SDK. MFC is a thin wrapper around the Windows SDK. Sometimes you need the real thing! Definitely needed in Multithreading.
Cannot Help it, You need to study more before we can help you.
Bram
Bram van Kampen
|
|
|
|
|
Hi
I have 3 rows of text in my rich edit.
At the end of each line I move a carriage return line feed, to force a new line
/r/n. Do these 2 bytes count as 2 characters when determining the count for the selection
Thanks
|
|
|
|
|
The documentation at EM_GETSELTEXT message (Windows)[^] does not explicitly say whether it does, or does not. But a simple test should prove it one way or another.
|
|
|
|
|
cr/lf 0X0D0A is treated as 1 character for rich edit purposes
thanks
|
|
|
|
|
Really? I just tested (using VS2008) and it came out as two separate characters. Here's the code I used:
void CMyDialog::OnClickedOk()
{
int len = m_richedit.GetWindowTextLength();
TRACE(_T("Len = %d\n"), len);
CString text;
m_richedit.GetWindowText(text);
TRACE(_T("Text = %s\n"), text);
for (int x = 0; x < len; x++)
TRACE(_T("%#x\n"), text[x]);
} The resulting output looked like:
Len = 7
Text = David
0x44
0x61
0x76
0x69
0x64
0xd
0xa
"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
"You can easily judge the character of a man by how he treats those who can do nothing for him." - James D. Miles
|
|
|
|
|
I was referring to richedit when determining the selection position
|
|
|
|
|
So you are taking whatever text is already present in the edit control and adding CRLF to the end of it? I'm trying to ascertain if this is an appending issue (I've seen some weird ways in which folks try to append to an edit control) or something else.
"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
"You can easily judge the character of a man by how he treats those who can do nothing for him." - James D. Miles
modified 9-Mar-16 11:41am.
|
|
|
|
|
For Crlf which is 2 bytes in memory aka the buffer
I count 1 for determining the selection count
|
|
|
|
|
But are taking whatever text is already present in the edit control and adding CRLF to the end of it?
"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
"You can easily judge the character of a man by how he treats those who can do nothing for him." - James D. Miles
|
|
|
|
|
The text is included in the count for the cold I count as 1 character for porpouses of selection not 2 bytes
|
|
|
|
|
I misunderstood what you were attempting.
You are using the GetSel() method to get the starting and ending positions of the control's selected text, correct? I tried that and with all of the text in the control selected, I found that CR and LF are (like I would expect) considered two separate characters. In other words, start = 0 and end = 7.
"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
"You can easily judge the character of a man by how he treats those who can do nothing for him." - James D. Miles
|
|
|
|