|
hi!
I want to change backgrouncolor of myapplication.I'm trying to make something with mfc.but I am new for mfc.....
Thanks!!!
|
|
|
|
|
BOOL CYourView::OnEraseBkgnd(CDC* pDC)
{
CView::OnEraseBkgnd(pDC);
CRect r;
GetClientRect(&r);
pDC->FillSolidRect(&r,RGB(127,127,0));
return true;
}
Author of the romantic comedy
Summer Love and Some more Cricket [New Win]
|
|
|
|
|
There is no point calling the base method as far as I can see. You're about to undo what it does anyhow.
Christian
I am completely intolerant of stupidity. Stupidity is, of course, anything that doesn't conform to my way of thinking. - Jamie Hale - 29/05/2002
Half the reason people switch away from VB is to find out what actually goes on.. and then like me they find out that they weren't quite as good as they thought - they've been nannied. - Alex, 13 June 2002
|
|
|
|
|
How do you change the background color of a CListBox. There isn't a SetBkColor and I tried the CDC::SetBkColor unsuccessfully. I may have done it wrong but this is where I am stuck. Thank you for your help in advance.
Bill
|
|
|
|
|
|
thanks nish.there is a lots of tips and tricks with u..well done...
Renjith-CPian
|
|
|
|
|
Thanks, I was allready overriding OnCtlColor and just needed to add an else if. Worked like a champ.
Bill
|
|
|
|
|
I'm trying to create a single instance standalone dialog box with the SetforegroundWindow. Should I register the class and use Findwindow.
Thanks
|
|
|
|
|
|
to ensure your application runs only one instance
on your InitInstance()
{
CreateMutex(NULL,false,"ur app");
if(GetLastError()=ERROR_ALREADY_EXISTS)
{
//alredy there is an instance present
//return/something u want to do here
}
}
just Look the previous messageboard entries
i told it a thousand times..!!!!
Renjith-The CPian.
|
|
|
|
|
This error is popping up sporadically upon calling CFile::Flush(). Does anyone know what might cause this call to fail sporadically with this error message?
"an unknown error occurred while accessing an unnamed file"
: Dean 'Karnatos' Michaud
|
|
|
|
|
I've seen that error -- You get that error if the file was not opened successfully or some permissions are incorrect.
|
|
|
|
|
I've created an array of unsigned chars as a parity table. During program initialization, I originally memset the array to all zeros. In the same init sequence, I set elements of the array to one to signify that the parity bit should be set for that particular value.
// in header file
#define RADAR_PARITYTBLSZ 4096
unsigned char RadarParityTable[RADAR_PARITYTBLSZ];
// in .C file
// Initialize parity table for 12 bit radar msgs and 1 bit of parity
memset(&RadarParityTable, 0, sizeof(RadarParityTable));
for(i = 0; i < RADAR_PARITYTBLSZ; i++)
if(ComputeParity(i) == 0) // this returns 0 if value of i is even
RadarParityTable[i] = 1;
The problem is that the last element of the array, in this case [4095], (the array is 4096 bytes in size, is mysteriously set to 0x20 instead of 1. I'm using odd parity so the parity for a value of 0xfff or 4095 -- 12 binary bits set means add one to it to make it odd.
I set a breakpoint right after the code above in the init sequence and Quickwatch says ALL of the values are zero. Later when I compare parity to the parity table in another module and use quickwatch, the value for that element is 0x20. The only way I was able to fix this was to increase the size of the array by 1 to 4097, initialize the first 4096 elements the same as before, and then all of the values in the array were correct even the last one. I even tried adding this line of code below in the init sequence but it didn't work.
RadarParityTable[RADAR_PARITYTBLSZ-1] = 1;
Any ideas why it was set to hex 0x20.
|
|
|
|
|
Nothing in the code that you show should have this result.
Why not use a data breakpoint in the debugger to see when the element is being overwritten?
Data breakpoints are set with Edit / BreakPoints and then selecting the Data tab.
Enter as the expression: RadarParityTable[4095]
Best regards,
John
|
|
|
|
|
I'll try that tomorrow. I'm at home now.
|
|
|
|
|
You probably have another array on the atck which is writing beyond its bounds. Take a look at the other vars declared next to your array.
Roger Allen
Sonork 100.10016
If I had a quote, it would be a very good one.
|
|
|
|
|
You were right and John Barton's suggestion helped me identify the problem though I still have to find out why. Apparently, that element in the array gets overwritten when I'm using strtok() on some other data. I'm not sure if it's because I'm using strtok in a thread or if I'm doing some bad pointer arithmetic.
I use strtok on a buffer and then later do...
*(p - 1) = ' ';
because I need to place spaces back into the buffer so that I can look for two spaces. It could be that statement. Anyways, thanks for the help, guys.
|
|
|
|
|
*(p - 1) = ' ';
will put a space character in the byte imedieatly preceeding the location pointed to by p. If p is a pointer to the location after your buffer, the last character of your buffer will become a 0x20 (space character).
|
|
|
|
|
Yes. That space however is going to the end of the wrong array, RadarParityTable. I have to parse another buffer, a file header, and treat the data differently when it encounters two spaces. Because strtok puts a 0x00 or '\0' at the end of each substring where the token exists, the data will be in EBCDIC when written to disk, I had to replace the spaces that strtok put into it. So, I did as you say put a space preceding the spot where strtok found the next substring of data.
I must be corrupting that memory somehow, though boundschecker active mode is not catching it. Its funny though that changing the size of the RadarParityTable from 4096 to 4097 fixed the problem.
|
|
|
|
|
JohnnyG wrote:
memset(&RadarParityTable, 0, sizeof(RadarParityTable));
to
memset(RadarParityTable, 0, sizeof(RadarParityTable));
Did you corrected this ???
Hth....;)
Ramu
|
|
|
|
|
Sorry, I didn't answer. I did not get to it but I believe that when I don't put the address of operator (&) it says something about parameter 1 not being right. That's why I used &RadarParityTable. I'll check again if I have time tomorrow. I know that parameter 1 should be a void pointer. Thanks
|
|
|
|
|
What error message does it exactly give ???
Using '&' is not correct.
Thanks,
Ramu
|
|
|
|
|
You were right Ramu. I had gotten this msg earlier:
'memset' : actual parameter is not a pointer : parameter 1
but that was for a structure. So, when I coded the statement for an array I used the same technique. Now, I see the errors of my way.
|
|
|
|
|
BTW, The way I'm doing it now doesn't give me any warnings and when I breakpoint after the memset, the entire array is equal to zeroes.
|
|
|
|
|
I fixed it. Thanks, everybody. It turns out that on the very first call to strtok and all subsequent calls, I was placing the '\0' that strtok appends to each substring with a space. However, on the first call to strtok, there is no space (my token) before it, and thus I was placing a space into a memory address where my other array's end element existed.
|
|
|
|