|
What if you use the WS_CLIPSIBLINGS style on the windows?
Mark
Mark Salsbery
Microsoft MVP - Visual C++
|
|
|
|
|
Hi Mark, thank you very much
Using WS_CLIPSIBLINGS on the child window that should be topmost places it behind all child windows
That could be a solution also if it isn't what I was looking for
---
|
|
|
|
|
I don't understand the design of your dialog. You have controls overlapping... maybe something is missing in your example screenshot?
|
|
|
|
|
I agree with Moak - I don't understand the design. You're pretty much getting the behavior you
ask for there.
Mark Salsbery
Microsoft MVP - Visual C++
|
|
|
|
|
Uhm, how about creating a child window that act like a split window?
Could it be a solution?
---
|
|
|
|
|
4288 wrote: Could it be a solution?
Depends on what you want to do. How about describing your problem from a different angle? Instead of picking a specific implementation/layout maybe tell instead about the wanted functionality and user experience.
|
|
|
|
|
Id like to muse a child window as a splitter window on the right
The problem is that this child window can be taken (by resizing right side)over another child window with controls.. and the problem above rises
Maybe moving the child on right and preventing user from moving it..?
---
|
|
|
|
|
For me a splitter window would resize controls in a window... so if the controls didn't overlap in the beginning they also will not later (after the splitter bar was moved).
If you haven't looked into a splitter window implementation here on CodeProject (or another MFC variant), I would suggest trying that.
Hope it helps
/M
|
|
|
|
|
I will try it, any problem I will let you know.
And if my project will be good, I'll post it here on cp
---
|
|
|
|
|
Mark Salsbery wrote: Mark Salsbery
Microsoft MVP - Visual C++
Mark, what is the secret behind making the nice coffee smiley? Hmm... :coffee:
|
|
|
|
|
if I told you it wouldn't be a secret *cough*java*cough*
Mark Salsbery
Microsoft MVP - Visual C++
|
|
|
|
|
:cappuccino: :espresso: :caffeine: ...
Thx
|
|
|
|
|
Is there a way to remove the maximize box from the view title bar in a multidoc app? I used DeleteMenu(*) or ModifyStyle(*) to disable the maximize button but these do not remove the button from the title bar. Thanks in advance.
|
|
|
|
|
When you create the window dont set the WS_MAXIMIZEBOX style, if your using MFC check under the CWnd::PreCreateWindow method of your windows class and you can change the style from there before the window is created.
Gavin Taylor
|
|
|
|
|
Hmmm, I tried that in the CMainFrame::PreCreateWindow(CREATESTRUCT& cs) by setting:
cs.style &= ~WS_MAXIMIZEBOX
before the call to CMDIFrameWnd::PreCreateWindow(cs) which disabled the maximize box but did not remove the button from the title bar. Am I doing that wrong?
|
|
|
|
|
|
I'm using VC 6++ and MFC. The project has some fortran modules in it.
I get linker errors like these:
dfor.lib(matherr.obj) : error LNK2005: __matherr already defined in msvcrtd.lib(merr.obj)
libc.lib(fpinit.obj) : error LNK2005: __ldused already defined in a previous module
libc.lib(fpinit.obj) : error LNK2005: __fltused already defined in a previous module
and more
also
BUBBC.OBJ : error LNK2001: unresolved external symbol _THEPAR@4
BUBBC.OBJ : error LNK2001: unresolved external symbol _EXPARG@4
BUBBC.OBJ : error LNK2001: unresolved external symbol _BDOSE@8
where bubbc.for is the fortran file.
Any input is appreciated.
thnaks,
sb
|
|
|
|
|
Hi,
Try changing your Fortran to debug multithreaded and then try integrate it with VC++.
Thanks,
Suman
--
"Programming is an art that fights back!"
|
|
|
|
|
Hi Suman,
The fortran modules are just .for text files that reside in the project. They aren't compiled separately and linked. If I make a win32 console app and include these .for files as source files, the app compiles, links and runs fine. I have Visual Fortran on the machine and Visual Studio seem to know what to do in the case of a win32 app. But for an MFC app, it gives linker errors. I dont have a separate fortran project.
thanks,
sb
|
|
|
|
|
Is this correct? What i am attempting to ensure is that the arrErrCode[i]var is being passed by reference to the TestMyStuff method. The question is by using a LPTSTR vs. an &, i should get the same result correct?
Main
{
For (int 1= 0; i<2; i++)
{
arrErrCode[i] = new TCHAR[16];
ZeroMemory(arrErrCode[i], 16 * sizeof(TCHAR))
if (TestmyStuff(arrErrCode[i]))
//do something here with arrErrCode[i]
}
}
BOOL TestMystuff(LPTSTR szCode)
{
StrCpy(szCode, TEXT("000"));
return TRUE;
}
|
|
|
|
|
LCI wrote: BOOL TestMystuff(LPTSTR szCode)
That is passing a pointer by value.
led mike
|
|
|
|
|
So if i wanted to do it by reference then i would add an &
to the function definition like :
TestMyStuff(LPTSTR& szCode)
{
}
I have never worked with LPTSTR's so i am just a tad confued with how to pass by reference using LPTSTR
|
|
|
|
|
You don't need it. LPTSTR is just a reassuring name given to a pointer type.
If the Lord God Almighty had consulted me before embarking upon the Creation, I would have recommended something simpler.
-- Alfonso the Wise, 13th Century King of Castile.
This is going on my arrogant assumptions. You may have a superb reason why I'm completely wrong.
-- Iain Clarke
|
|
|
|
|
A LPTSTR is a pointer to a char array. So you don't need to pass it by reference unless you want to change it size (in fact, allocating a new array). If you only wants to modify the contents, then you can pass the pointer.
|
|
|
|
|
LCI wrote: So if i wanted to do it by reference then i would add an &
Yes but the only reason to pass a pointer by reference is to change the value of the pointer (the address). Is that what you need to do? I would not guess that from the code you posted.
led mike
|
|
|
|