|
Sure. In my code I give it an empty CRect, and it work fine.
|
|
|
|
|
Please correct me if i am wrong. While creating a Split window using below statement.
bStatus = GetSplitterObj()->CreateView
(
1,
1,
RUNTIME_CLASS(CMyTabClass),
sizeView,
pContext
);
Above call create Split Window. CMyTabClass is derived from CTabView. So, by default the split window should contain tab splitter at the bottom of the window. Am i right?
Because this is how it working in my sample application. In sample i created a Class which derives from CTabView and the window is created with tab splitter in the bottom by default. Later i started adding view using addview().
Then why in my application, splitter is not visible in bottom of the splitter window? why should i explicitly create it using Create()..?
|
|
|
|
|
The code:
bStatus = GetSplitterObj()->CreateView
(
1,
1,
RUNTIME_CLASS(CMyTabClass),
sizeView,
pContext
);
it is only put CMyTabClass view into your splitter window. The creation of the tabs inside this CMyTabClass should be done in CMyTabClass::OnCreate, where AddView(...) calling is mandatory.
So, you should add at least one tab in order to see something inside your splitter window
|
|
|
|
|
Then how come in sample application, below code itself creating a tab bar (horizontal with arrow buttons) in window?
if (CTabView::OnCreate(lpCreateStruct) == -1)
return -1;
The same above piece of code in my application not creating that horizontal tab bar unless i create
MFCTabCtl tab;
tab.create()....
|
|
|
|
|
If i call AddView() and run my program, it working absolutely fine with a window and a view(tab).
But instead of calling AddView() initially, at runtime i based on user input, i called addview() which leads to a crash. What could be the reason.
class View : public CScrollView
{
}
class MyTabClass : public CTabView
{
void OnCreate(LPCREATESTRUCT lpCreateStruct)
{
if (CTabView::OnCreate(lpCreateStruct) == -1)
return -1;
AddView(RUNTIME_CLASS(View),_T("Sheet1"));
}
void RunTimeBasedOnUserInput()
{
for(int i = 0 ; i < userinput; i++)
{
AddView(RUNTIME_CLASS(View),_T("sheet %d",i));
}
}
}
After investigation, what i found is, During creation of window itself, OnInitUpdate function in class View is getting called each time when AddView() is called.
But if i create the views dynamically, then AddView() wont call OnInitUpdate of my View class and hence the crash occurs.
Exception as follows:
---------------------------
Microsoft Visual C++ Runtime Library
---------------------------
Debug Assertion Failed!
Program: C:\Windows\SYSTEM32\mfc140d.dll
File: f:\dd\vctools\vc7libs\ship\atlmfc\src\mfc\afxtabview.cpp
Line: 102
For information on how your program can cause an assertion
failure, see the Visual C++ documentation on asserts.
(Press Retry to debug the application)
---------------------------
Abort Retry Ignore
---------------------------
Can you let me know how to get rid of this problem?
modified 13-Mar-18 1:03am.
|
|
|
|
|
If i call AddView() and run my program, its working absolutely fine with a window and a view(tab).
But instead of calling AddView() initially, at runtime based on user input, i called addview() which leads to a crash. What could be the reason.
<pre>class View : public CScrollView
{
}
class MyTabClass : public CTabView
{
void OnCreate(LPCREATESTRUCT lpCreateStruct)
{
if (CTabView::OnCreate(lpCreateStruct) == -1)
return -1;
AddView(RUNTIME_CLASS(View),_T("Sheet1"));
}
void RunTimeBasedOnUserInput()
{
for(int i = 0 ; i < userinput; i++)
{
AddView(RUNTIME_CLASS(View),_T("sheet %d",i));
}
}
}
|
|
|
|
|
And what did exactly didn't work when you had applied my example ?
|
|
|
|
|
On splitter window tab control not added. tab.Create() function returns true but tab control is not visible on splitter window.
|
|
|
|
|
In above provided sample code, i have some doubts.
When i created a class CTabbedView which is inherited from CTabView, in OnCreate(), the below call it self created a tab control (horizontal splitter) without any tabs.
if (CTabView::OnCreate(lpCreateStruct) == -1)
return -1;
Then what is the use of below call?
if (!m_tab.Create(CMFCTabCtrl::STYLE_3D, CRect(0, 0, 500, 100), this, 1, CMFCTabCtrl::LOCATION_BOTTOM))
{
TRACE(_T("Failed to create output tab window\n"));
return -1;
}
What is the exact difference between AddTab and AddView.?
|
|
|
|
|
AddTab call is creating the tab area:
"Call this method to add a pane as a new tab on a tabbed pane"
CBaseTabbedPane Class[^]
and AddView call is creating the view which are hosted by CTabView:
"Call this function to add a view to the tab control that is embedded in a frame"
CTabView Class[^]
|
|
|
|
|
In my case, i need to create tabs dynamically. Lets say. When my application starts user will input a value between 1 to 10. Based on user input i need to create the tabs (no. of tabs).
later in each tab in need to display different images.
In this case, should i create my class which is inheriting from CTabView or CTabPane?
|
|
|
|
|
" should i create my class which is inheriting from CTabView or CTabPane?" Definitely from CTabView.
And this CMyTabClass, should include at least one tab, with one view.
|
|
|
|
|
If i call AddView(), this itself is creating a tab. Is this not enough? No need to call AddTab() right?
|
|
|
|
|
Yes, AddView() is creating a tab, so, it is enough.
|
|
|
|
|
If i call AddView() and run my program, its working absolutely fine with a window and a view(tab).
But instead of calling AddView() initially, at runtime based on user input, i called addview() which leads to a crash. What could be the reason.
class View : public CScrollView
{
}
class MyTabClass : public CTabView
{
void OnCreate(LPCREATESTRUCT lpCreateStruct)
{
if (CTabView::OnCreate(lpCreateStruct) == -1)
return -1;
AddView(RUNTIME_CLASS(View),_T("Sheet1"));
}
void RunTimeBasedOnUserInput()
{
for(int i = 0 ; i < userinput; i++)
{
AddView(RUNTIME_CLASS(View),_T("sheet %d",i));
}
}
}
|
|
|
|
|
Hi. Have you solved this ?
|
|
|
|
|
I am serializing CMapStringToPtr object without any problem, key by key, pointer to pointer.
For this case, the key order it is matter.
So, if I archive this CMapStringToPtr object, and de-archive on the same machine, the key order are fine. But, if I de-archive this object on other machine, the key order are not the same, and this is a PROBLEM. How can avoid this issue ?
Yes, I could serialize another CStringArray with the CMapStringToPtr keys, but I don't know if this a good idea ... can you tell me how to overcome this problem ?
Thank you.
|
|
|
|
|
Key order is not a property of such a collection (see the documentation[^]) unlike, for instance, the std::map .
So yes, you have to work around that.
|
|
|
|
|
Hello Everybody,
I am trying to read XML file using MSXML parser. Till now, all paths are in English characters and inside file also all are in English only.
Now, we are trying to move with Chinese characters also. So, inside file wherever needed, we are able to manage conversion and load the file using MSXML parser.
Now, the problem is, if the path of the xml file consists of Chinese characters, then
IXMLDOMDocumentPtr->load(path)
is not working.
Is there anyway to load the file ?
PS. we can able to write a new parser, but need to change a lot in our existing application.
Thanks in advance.
Regards,
Gopinath.
|
|
|
|
|
Gopi Nath wrote: is not working What does that mean?
|
|
|
|
|
Hello Richard,
MSXML::IXMLDOMDocumentPtr->load function, when I tried to load a file in which the path or file name contains Chinese characters, its not loading. Means, it fails to load the file into the document pointer and return false.
Regards,
Gopinath.
|
|
|
|
|
|
Thanks Richard,
I will check and will get back to you on this.
Regards,
Gopinath.
|
|
|
|
|
Do you need to canonicalize the path?
"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
|
|
|
|
|
Perhaps, there is some problem with encoding?
|
|
|
|