|
Hmmm I don't know about WinCE unfortunately.
CImage wraps a little GDI+ for loading and saving, and also wraps a
HBITMAP/DIBSection, which works with TransparentBlt() just fine (in
fact, the class has a TransparentBlt() method). Again, I'm not sure about
WinCE compatibility though.
If you have a little project that doesn't work that I can test on regular
Windows I'll check it out.
Good luck
Mark
Mark Salsbery
Microsoft MVP - Visual C++
|
|
|
|
|
Hi,
Everything in normal windows can be done in CE, sometimes you just need to go about it a bit differently.
I have cut out everything from my project and managed to write a non-working class if you are interested. I wont have access to CE again until monday so wont be able to test the dialog thing yet.
Below is the code, it is very simple as you can probably see. Just call the .CreateTransparent(this); and you should get a nice streak down the form.
Once again, thanks for your help!
MS.
The .H;
<br />
class CNotWorking :<br />
public CWnd<br />
{<br />
public:<br />
CNotWorking(void);<br />
~CNotWorking(void);<br />
void CreateTransparent(CWnd *pParent);<br />
<br />
DECLARE_MESSAGE_MAP()<br />
afx_msg void OnPaint();<br />
afx_msg void OnTimer(UINT nIDEvent);<br />
<br />
private:<br />
CRect rTextRect;<br />
UINT tTicker;<br />
<br />
};
//////////
And the .CPP;
<br />
BEGIN_MESSAGE_MAP(CNotWorking, CWnd)<br />
ON_WM_PAINT()<br />
ON_WM_TIMER()<br />
END_MESSAGE_MAP()<br />
<br />
<br />
CNotWorking::CNotWorking(void)<br />
{<br />
rTextRect.SetRect(0, 0, 40, 20);<br />
tTicker = 0;<br />
<br />
}<br />
<br />
CNotWorking::~CNotWorking(void)<br />
{<br />
}<br />
<br />
void CNotWorking::CreateTransparent(CWnd *pParent)<br />
{<br />
CWnd::CreateEx(NULL, NULL, _T("Transparent"), WS_CHILD, 20, 20, 500, 500, pParent->GetSafeHwnd(), NULL);<br />
<br />
tTicker = ::SetTimer(*this, (UINT_PTR)12345, 20, NULL);<br />
<br />
ShowWindow(SW_SHOW);<br />
}<br />
<br />
void CNotWorking::OnPaint()<br />
{<br />
CPaintDC dc(this);
<br />
<br />
dc.SetBkMode(TRANSPARENT);<br />
CString textStr = "test";<br />
dc.DrawText(textStr, &rTextRect, DT_LEFT | DT_TOP);<br />
<br />
<br />
}<br />
<br />
void CNotWorking::OnTimer(UINT nIDEvent)<br />
{<br />
InvalidateRect(rTextRect);<br />
rTextRect.OffsetRect(0, 2);<br />
UpdateWindow();<br />
<br />
CWnd::OnTimer(nIDEvent);<br />
}
|
|
|
|
|
Your code works for me.
In OnTimer(), I had to change
InvalidateRect(rTextRect);
to
InvalidateRect(&rTextRect);
Mark
Mark Salsbery
Microsoft MVP - Visual C++
|
|
|
|
|
Mark Salsbery wrote: Your code works for me.
Really???
I have tried both but I still get the smudge either way (I have only tested on XP).
|
|
|
|
|
Yes, really
The change I made wasn't even necessary, since CRect has a LPRECT
operator.
I'm testing on Vista.
Is it leaving a trail of pixels or does the entire text get left
behind on previous draws?
Mark
Mark Salsbery
Microsoft MVP - Visual C++
|
|
|
|
|
The entire text gets left behind (in the image below I have used 'rTextRect.OffsetRect(0, 20);' to space them out a bit to show this).
http://i19.tinypic.com/8a4gh2w.jpg
Thanks
MS.
|
|
|
|
|
Hmm that shouldn't happen
WM_ERASEBKGND should redraw the background for the invalidated
rect when the CPaintDC is created (during the internal call
to BeginPaint().
Can you add a WM_ERASEBKGND that calls the base class method?
Then in that handler, maybe draw a rectangle at the textrect.
Mark
Mark Salsbery
Microsoft MVP - Visual C++
|
|
|
|
|
Mark Salsbery wrote: you don't need to preserve a DC between WM_PAINT messages.
ummm.... don't you mean you should not?
|
|
|
|
|
led mike wrote: don't you mean you should not?
For the sake of this thread - yes.
Discussing owned DCs is beyond the scope of the problem/OP/thread, IMO
Mark
Mark Salsbery
Microsoft MVP - Visual C++
|
|
|
|
|
Are you using Invalidate () before calling UpdateWindow () ??
It mades the drawing surface to be erased and then repainted, so the old text will be away, and just the new "repositioned" will be drawn.
Greetings.
--------
M.D.V.
If something has a solution... Why do we have to worry about?. If it has no solution... For what reason do we have to worry about?
Help me to understand what I'm saying, and I'll explain it better to you
“The First Rule of Program Optimization: Don't do it. The Second Rule of Program Optimization (for experts only!): Don't do it yet.” - Michael A. Jackson
|
|
|
|
|
As the subject says,
I'm building a virtual keyboard on a WINCE 5.0 device.
I'm stuck with the function keys (CTRL,SHIFT,CAPS,ALT).
I know that I gotta change some flags, but how?
I have tried SendVirtualKey(VK_CAPITAL,KeyShiftCapitalFlag); // doesn't work
and also SendVirtualKey (VK_CAPITAL,KEYEVENTF_KEYUP) // doesn't work
and also SendVirtualKey (KeyShiftCapitalFlag,KEYEVENTF_KEYUP) doesn't work
Any suggestions?
Thank you!
|
|
|
|
|
hi,
how to use multi column combo box in a dialog? how can add strings into the multi column combo box. actually i was used this code
m_ComboBoxControl1.AddRow(ColumnString0, ColumnString1);
but it was not functioning.
can you please help me
Thanks,
Panthal
|
|
|
|
|
Forgive my ignorance....what multi-column combobox?
Mark
Mark Salsbery
Microsoft MVP - Visual C++
|
|
|
|
|
Mark Salsbery wrote: what multi-column combobox?
...looks around cautiously...
Psst, Mark. It's the one over there.
"Normal is getting dressed in clothes that you buy for work and driving through traffic in a car that you are still paying for, in order to get to the job you need to pay for the clothes and the car and the house you leave vacant all day so you can afford to live in it." - Ellen Goodman
"To have a respect for ourselves guides our morals; to have deference for others governs our manners." - Laurence Sterne
|
|
|
|
|
hmm...
Mark Salsbery
Microsoft MVP - Visual C++
|
|
|
|
|
Hello everyone,
I can not understand how the following code works and assign 100 to counter variable?
void Foo (int* input)
{
*input = 100;
return;
}
#define GETFOO (Foo( &counter ), counter)
int counter;
int main()
{
GETFOO;
return 0;
}
thanks in advance,
George
|
|
|
|
|
the macro expands to
(Foo( &counter ), counter);
on running:
Foo(&counter) is first evaluated and it sets counter=100 , then counter is evaluated giving the result 100 to the expression inside the outer braces, finally the result itself it is discarded.
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.
|
|
|
|
|
Thanks CPallini,
I do not understand how this statement works,
(Foo( &counter ), counter);
I have tested that the simple statement (without comment) also works. What is the benefit and function to add , and counter in macro definition?
// #define GETFOO Foo((&counter), counter)
#define GETFOO Foo(&counter)
regards,
George
|
|
|
|
|
George_George wrote: I do not understand how this statement works,
(Foo( &counter ), counter);
Both I and toxcct gave an answer to the above.
George_George wrote: I have tested that the simple statement (without comment) also works.
Of course.
George_George wrote: What is the benefit and function to add , and counter in macro definition?
The difference stands in the returned value of the expression, for instance
void Foo (int* input)
{
*input = 100;
return;
}
#define GETFOO (Foo( &counter ), counter)
void main()
{
int i = GETFOO;
}
will assign 100 to i .
Anyway that way of coding is simply junk.
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.
|
|
|
|
|
Cool CPallini,
Thanks!
regards,
George
|
|
|
|
|
I gave you 5 everywhere in this thread, so did I to Iian.
answering George_george deserve courage and patience !!!
|
|
|
|
|
|
CPallini wrote: OMG, definitely you aren't my friend!
please tell me this is a joke hey !
CPallini wrote: Only 5?
i am negociating with the site administrators to leverage the votes on G_G thread up to at least 10 ! lol
BTW, please do the same to me
let's get stronger again that kid.
|
|
|
|
|
toxcct wrote: BTW, please do the same to me
Done buddy!
But you understand that it cannot be our voting guideline unless we want to be hounded out CP for violating the Competition Law.
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.
|
|
|
|
|
hey, we're not enforcing anything. we're just reacting to G_G voting bad habit.
we're all good guyz here, so what's bad in this ?! lol.
|
|
|
|