|
Because the info you provided is not enough, I can not be sure that you are doing correctly. Here is the check list for you.
1) One must add data elements into an array container, then he can enumerate the elements in the container. Getting elements from an empty container would result in access violation.
2) Before invoking CDialog::Create , the pointer of type CDialog* needs to be new -ed.
3) The for loop shall check the actual size of the array by calling CArray::GetCount . That is,
for(int nCount=0; nCount < dlgArray.GetCount(); nCount++)
Maxwell Chen
|
|
|
|
|
First Thank you all for replays. I'm still stack. So I will give you additional information . Please excuse my English I still learning. First I create the Array in my header file with template, like this:
CArray<CDialog *, CDialog *> dlgArray;
Then in my .cpp file I add some data:
dlgArray.Add(new CDlgSettings());
And I want to use this data by this way:
m_nPageCount = 1;<br />
for(int nCount=0; nCount < m_nPageCount; nCount++)<br />
dlgArray.GetAt(nCount)->Create(m_DialogPages[nCount],GetParent());
My idea is to use the above code to insert dialog into Tab Control. The project is compiling without error, but when i try to open the dialog which contains the Tab Control I receive the folowing error.
Asseration Failed!<br />
MyProgram: File afxwin2.inl, Line 262
modified on Sunday, January 06, 2008 3:12:48 AM
|
|
|
|
|
babamara wrote: dlgArray.GetAt(nCount)->Create(m_DialogPages[nCount],GetParent());
1) Make sure that m_DialogPages[nCount] refers to a valid dialogbox resource ID.
2) Let's say, dialogbox A has a tab control. In the implementation of A, it creates some child dialogboxes. I think that the second argument for CDialog::Create should be this , not GetParent .
3) Make sure the dialogboxes to be held in the tab control have the property "child window ".
Maxwell Chen
|
|
|
|
|
Thank you. I change GetParent with this and this solves the probelm. Now I am going to check why the dialog are not shown in my Tab Control.
|
|
|
|
|
babamara wrote: Now I am going to check why the dialog are not shown in my Tab Control.
Try CDialog::ShowWindow(SW_SHOW) .
Maxwell Chen
|
|
|
|
|
I use this function
void CPropertyTabControl::ActivateTabDialogs()<br />
{<br />
int nSel = GetCurSel();<br />
if(dlgArray[nSel]->m_hWnd)<br />
dlgArray[nSel]->ShowWindow(SW_HIDE);<br />
<br />
CRect l_rectClient;<br />
CRect l_rectWnd;<br />
<br />
GetClientRect(l_rectClient);<br />
AdjustRect(FALSE,l_rectClient);<br />
GetWindowRect(l_rectWnd);<br />
GetParent()->ScreenToClient(l_rectWnd);<br />
l_rectClient.OffsetRect(l_rectWnd.left,l_rectWnd.top);<br />
for(int nCount=0; nCount < m_nPageCount; nCount++)<br />
{<br />
dlgArray[nCount]->SetWindowPos(&wndTop+21, l_rectClient.left,<br />
l_rectClient.top, l_rectClient.Width(), l_rectClient.Height(),<br />
SWP_HIDEWINDOW);<br />
}<br />
dlgArray[nSel]->SetWindowPos(&wndTop+21, l_rectClient.left,<br />
l_rectClient.top, l_rectClient.Width(), l_rectClient.Height(), SWP_SHOWWINDOW);<br />
<br />
dlgArray[nSel]->ShowWindow(SW_SHOW);<br />
<br />
}
|
|
|
|
|
babamara wrote: dlgArray[nCount]->SetWindowPos(&wndTop+21, l_rectClient.left, l_rectClient.top, l_rectClient.Width(), l_rectClient.Height(),
SWP_HIDEWINDOW);
1) Which target does &wndTop+21 point to?
2) Since you've invoked CWnd::SetWindowPos with the flag SWP_SHOWWINDOW , there is no need to invoke CWnd::ShowWindow(SW_SHOW) again.
Maxwell Chen
|
|
|
|
|
babamara wrote: SetWindowPos(&wndTop+21
?!?
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.
[my articles]
|
|
|
|
|
Hi,
I have the following class declared:
// header file
class classA
{
protected:
static classA *a;
static void setClassA(classA *pa);
}
// *.cpp file
#include "classA.h"
void classA::setClassA(classA *pa)
{
classA::a = pa;
return;
}
This code compiles just fine but it does not link.
The error I get is:
unresolved external symbol "protected static class classA *classA::a"
|
|
|
|
|
You need to define the static member pointer. Write the following statement in the source (*.cpp ) file
classA * classA::a = NULL;
BTW you missed a semicolon at the end of the class declaration.
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.
[my articles]
|
|
|
|
|
Thank you for the quick response. It works now.
I have been doing some research in the meantime.
I am not sure if I understand why I have to do this extra reference.
Is it because static limits the visibility of the variable to the include <.h> file?
|
|
|
|
|
jupiter1000 wrote: I am not sure if I understand why I have to do this extra reference.
Is it because static limits the visibility of the variable to the include <.h> file?
According to MSDN [^]
Static data members are not part of objects of a given class type; they are separate objects. As a result, the declaration of a static data member is not considered a definition. The data member is declared in class scope, but definition is performed at file scope. These static members have external linkage
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.
[my articles]
|
|
|
|
|
Hey, I use my printer dc to paint some text and graphic to my printer. I use MM_LOMETRIC as Mapmode because of the easy way of positioning. Now I have a big problem to print bitmaps. All bitmaps are mirrowed (around X-axis).
I use the following code to paint the bitmap:
<br />
<br />
<br />
....<br />
CBitmap *pBitmap = new CBitmap();<br />
HBITMAP hBitmap;<br />
hBitmap = (HBITMAP)::LoadImage(AfxGetInstanceHandle(),szPathToBitmap,IMAGE_BITMAP,0,0,LR_LOADFROMFILE|LR_CREATEDIBSECTION);<br />
pBitmap->Attach(hBitmap);<br />
...<br />
<br />
<br />
<br />
CRect reRect;<br />
<br />
reRect.left = 10;<br />
reRect.right = 300;<br />
reRect.top = -100;<br />
reRect.bottom = -1000;<br />
<br />
CDC dcMem;<br />
BITMAP bm;<br />
<br />
pBitmap->GetBitmap(&bm);<br />
dcMem.CreateCompatibleDC(pDC);<br />
dcMem.SelectObject(pBitmap);<br />
pDC->BitBlt(reRect.left, reRect.top, bm.bmWidth, bm.bmHeight, &dcMem,0,0, SRCCOPY);<br />
<br />
<br />
What's wrong, and how could I fix it?
|
|
|
|
|
Maybe try
pDC->StretchBlt(reRect.left, reRect.top, bm.bmWidth, -bm.bmHeight, &dcMem, 0, 0, bm.bmWidth, bm.bmHeight, SRCCOPY);
Mark
Mark Salsbery
Microsoft MVP - Visual C++
|
|
|
|
|
Thanks, this works fine for me (only the position is shifted), but why is the bitmap mirrored?
|
|
|
|
|
AnTri wrote: but why is the bitmap mirrored?
The Y-axis is flipped by MM_LOMETRIC and BitBlt() renders
scanlines in the positive direction from the starting point.
Mark
Mark Salsbery
Microsoft MVP - Visual C++
|
|
|
|
|
Hello everyone,
Should I delete memory pointed by pointer a if there is bad_alloc when allocating memory in memory pointed by pointer b? I am not sure whether there will be memory leak if I do not delete a.
try {
a = new int [N];
b = new int [M];
} catch (bad_alloc)
{
}
thanks in advance,
George
|
|
|
|
|
You have always to do your cleanup stuff!
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.
[my articles]
|
|
|
|
|
Thanks CPallini!
I think you mean we have to delete A, right?
regards,
George
|
|
|
|
|
Yes.
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.
[my articles]
|
|
|
|
|
Thanks for your confirmation, CPallini!
regards,
George
|
|
|
|
|
But I suggest he should do something like this :
<br />
if(pMyStuff!=NULL)<br />
{<br />
delete pMyStuff;<br />
}<br />
OK,. what country just started work for the day ? The ASP.NET forum is flooded with retarded questions. -Christian Graus
Best wishes to Rexx[^]
|
|
|
|
|
And you are right!
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.
[my articles]
|
|
|
|
|
Hello George, nice to see you again. But this time I've got a question for you. Straight to you. Why do are you acting 'quick'-judgemental before someone could actually reply you fully?
See here[^]
And I've seen many times , anybody who replies to your thread gets a 3 vote. Immediately. Is it a token of acknowledgment to say that you've read the message? . I'm really not hurt by that but I'm finding it funny! Why do you do that?
OK,. what country just started work for the day ? The ASP.NET forum is flooded with retarded questions. -Christian Graus
Best wishes to Rexx[^]
|
|
|
|
|
In a case like this you should initialize both a and b to 0 before the try clause. You cannot delete a or b at this stage, I assume you will need to use them later, or what was the purpose of allocating them?
int* a = NULL;
int* b = NULL;
try {
a = new int [N];
b = new int [M];
} catch (bad_alloc)
{
// Tell the user if a or b failed...
}
// Do some stuff on a or b
// Now delete if they are allocated
if(a)
delete a[];
if (b)
delete b[];
Thanks!
|
|
|
|