|
Hello,
I created a COM object in ATL, that copy the screen and
retrurn it, by: HBITMAP struct.
When I add a reference, the: .NET, convert this type to:
IntPtr.
OK, I call to the function, get the: IntPtr. And use:
Bitmap bmp= Image.FromHbitmap(myIntPtrObj);
But than I get this exception:
System.Runtime.InteropServices.ExternalException
with this describe:
A generic error occurred in GDI+.
Please help me, how to solve this exception...
Thank's alot,
Itay.
|
|
|
|
|
I have tried the sample post on this site. It works well, but I can't find a way to auto disconnect connexion after idle time.
I tried the rasgetentryproperties but I 've an got invalid parameter error.
Does anyone got an idea?
|
|
|
|
|
How annoying. The RichTextBox control doesn't appear to provide HTML, and the MailFormat enum doesn't include RTF. However am I supposed to provide an editor for formatted e-mails?
Seriously, though, any ideas/advice would be much appreciated.
|
|
|
|
|
I haven't looked up the .NET framework for candidate classes, but I would suggest you look up for classes able to support "multi-part mime types" as does the the web ocx (mhtml renderer). Indeed, rich emails (ie not only plain text) are made of that.
She's so dirty, she threw a boomerang and it wouldn't even come back.
|
|
|
|
|
Hello,
I am currently porting a webbrowser application from C++
to C#/.NET.
I already struggled with the beforenavigate2 bug everybody
was talking about and I can't wait for the .NET SP3.
My current problem is when trying to traverse the DOM tree
after a documentcomplete event. It works properly for non
framed document but not for framed pages.
Everytime a documentcomplete event is fired I always get
the same document (the top level one). It should mean that
I am always getting the same document, but I must be
missing something because I don't know how to get a
specific frame document.
Here is the C# piece of code:
<br />
private void documentComplete(object sender, <br />
AxSHDocVw.DWebBrowserEvents2_DocumentCompleteEvent e){<br />
<br />
AxSHDocVw.AxWebBrowser Frame;<br />
IHTMLDocument3 Doc;<br />
IHTMLDOMChildrenCollection Tags;<br />
IHTMLElement Tag;<br />
int NumTags;<br />
<br />
Console.WriteLine("URL: "+e.uRL);
try{<br />
Frame=(AxSHDocVw.AxWebBrowser)sender;
frame ?<br />
if(Frame!=null){<br />
Doc=(IHTMLDocument3)Frame.Document;
document ???<br />
if(Doc!=null){<br />
Tags=(IHTMLDOMChildrenCollection)Doc.childNodes;<br />
if(Tags!=null){ <br />
NumTags=Tags.length;<br />
for(int i=0;i<NumTags;i++){ <br />
Tag=(IHTMLElement)Tags.item(i);<br />
if(Tag!=null) traverseDOM(Tag);<br />
}<br />
}<br />
}<br />
}<br />
}<br />
catch(Exception ex){<br />
Console.WriteLine("Error: "+ex.ToString());<br />
}<br />
}<br />
Another question is: what is e.pDisp ? How to cast it ? It
tried to cast it into an AxSHDocVw.AxWebBrowser and I got
an error.
Regards,
R. L.
|
|
|
|
|
This article [^]might help you.
I have included frame events.
GriffonRL wrote:
what is e.pDisp ? How to cast it ? It
tried to cast it into an AxSHDocVw.AxWebBrowser and I got
an error.
This one should not really appear in public interfaces, but anyway, that's the instance of the underlying web browser control. You can't do much with C# about it, and in fact you don't need since the public IE interfaces are all available to you.
She's so dirty, she threw a boomerang and it wouldn't even come back.
|
|
|
|
|
Hello Stephane,
Thanks for your answer . I am looking at the article. But this pDisp is not clear for me.
You wrote:
This one should not really appear in public interfaces, but anyway, that's the instance of the underlying web browser control. You can't do much with C# about it, and in fact you don't need since the public IE interfaces are all available to you.
Since I used to write webbrowser applications with VC++, I was actually getting the frame browser control instance in pDisp. What I can't understand, is why e.pDisp exists if we can't cast it ?
Regards,
R. L.
|
|
|
|
|
GriffonRL wrote:
What I can't understand, is why e.pDisp exists if we can't cast it ?
the IE namespace you use once you have imported the IE web control ocx (drag&drop, add reference, ...) is actually the result of an automated type-library import which simply creates a thin wrapper around the idl interfaces. Because the IDispatch *pDisp appears in some members of some of the interfaces, it thus appears in the resulting wrapper.
But as I have said already, this is a case where it's not useful : IDispatch* is seen as a raw untyped object . Furthermore, the namespace already provides interfaces from which you can invoke the methods you would with a C++ ptr on the web control. So, you don't lose power by using C# or other .NET languages.
The thing you lose is that the marshaller (at the heart of all the interop stuff) is not able to comply with all kind of variant subtypes (limitation known by MS people). As long as MS doesn't fix it, whevener we import a type-library, we may or may not for any reason be able to call certain methods depending on the parameter types. That's it. We'll have to live with it. And by the way, the article I have suggested bypasses the standard tlbimp.
She's so dirty, she threw a boomerang and it wouldn't even come back.
|
|
|
|
|
Yep !
Here is the solution working with frames :
<br />
private void documentComplete(object sender, AxSHDocVw.DWebBrowserEvents2_DocumentCompleteEvent e){<br />
SHDocVw.IWebBrowser2 Frame;<br />
IHTMLDocument3 Doc;<br />
IHTMLDOMChildrenCollection Tags;<br />
IHTMLElement Tag;<br />
int NumTags;<br />
<br />
Console.WriteLine("URL: "+e.uRL);<br />
try{<br />
Frame=(SHDocVw.IWebBrowser2)e.pDisp;<br />
if(Frame!=null){<br />
Doc=(IHTMLDocument3)Frame.Document;<br />
Console.WriteLine("Document URL: " (IHTMLDocument2)Doc).location.href);<br />
if(Doc!=null){<br />
Tags=(IHTMLDOMChildrenCollection)Doc.childNodes;<br />
if(Tags!=null){<br />
NumTags=Tags.length;<br />
for(int i=0;i<NumTags;i++){<br />
Tag=(IHTMLElement)Tags.item(i);<br />
if(Tag!=null) traverseDOM(Tag);<br />
}<br />
}<br />
}<br />
}<br />
}<br />
catch(Exception ex){<br />
Console.WriteLine("F***: "+ex.ToString());<br />
}<br />
}<br />
Enjoy,
R. L.
|
|
|
|
|
I haven't run it, but I don't buy it. Why ? Not only MS clearly says in MSDN that frame events are signaled within their own frame space, but I know that there are 3 frame related events which actually get signaled on individual frames : that's FrameBeforeNavigate(dispid=200), FrameNavigateComplete(dispid=201) and FrameNewWindow(dispid=204).
That said, whatever the code you have, if it does what you are looking for, then it's probably because it's fine.
She's so dirty, she threw a boomerang and it wouldn't even come back.
|
|
|
|
|
GriffonRL-
Have you had success in trapping the navigation events in the browser?
-AC
|
|
|
|
|
Hi,
At least for DocumentComplete() it works. I also applied the "patch" to get BeforeNavigate2 events (until we get .NET SP3 . Everything else seems to work like in VC++/COM so far. But who knows ?
I am starting with .NET and it took me 1 day to learn C# and the .NET basics. But the marshalling system was not clear and I spent 2 days on problems.
Regards,
R. L.
|
|
|
|
|
Unfortunately, there is no .NET SP3 coming this fall.
.NET 1.1 is in beta, and this issue is not among the things that have been fixed (see gotdotnet.com for further details).
She's so dirty, she threw a boomerang and it wouldn't even come back.
|
|
|
|
|
Anyone know how to share memory between applications in DotNet for a realtime (Machine Control) application???
viva AMIGA
|
|
|
|
|
GlobalAlloc[^]
C++-->C# : You can use WIN32 GlobalAlloc and then use the handle in a C# app (thanks to PInvoke or the like).
C#-->C++. You can also use .NET AllocHGlobal and then pass the IntPtr (it's a pointer) down to C++ code (thanks to PInvoke or the like).
She's so dirty, she threw a boomerang and it wouldn't even come back.
|
|
|
|
|
When writing code in Visual Studio .NET the notational code dropdowns have tooltips next to them.
How do you write classes which produces this behaviour?
I think it's somthing to do with metadata, but not sure what or where...
Thanks
|
|
|
|
|
|
Thanks Marc
I am slowly comming to the conclusion that I will have to write in C#, and not VB.NET as this feature does not seem to be available in VB.NET.
I know this a C# forum, but I didn't think I would get an answer from the VB camp.
Looking at the solution I think I may have been wright.
|
|
|
|
|
You are correct. Under "Coding Techniques" for Visual Studio, I found the following:
If developing in C#, use the XML Documentation feature.
I suspect that only C# supports this feature because Microsoft pushed C# to be a standard, which it now is (supported by an outside standard committee not related to Microsoft--I can't remember the name). Another reason to code in C# and not VB (oops, biased statement!)
Marc
|
|
|
|
|
Hey all -
how exactly do you get the current date in C#? Last week when I writing a bunch of stuff in VB.NET, I was able to simply write:
new DateTime().Now().ToString()
Alas, it appears not so in C#... when I try to use Now as a static member I'm barked at and when I look at the default date the constructor initializes it is:
1/1/0001
Thanks much
*->>Always working on my game, teach me
*->>something new.
cout << "dav1d\n";
|
|
|
|
|
Fine for me, String dt = DateTime.Now.ToString();
She's so dirty, she threw a boomerang and it wouldn't even come back.
|
|
|
|
|
The wildest little inconsistency:
The DateTime class exposes Now as a static member in C# but allows you to get it as an instance member in VB.NET. In other words, you can say:
<br />
dim x as String = new DateTime().Now.ToString() <br />
in VB.NET
but in C# you cannot say:
<br />
string x = new DateTime().Now.ToString();<br />
Anyone know why?
*->>Always working on my game, teach me
*->>something new.
cout << "dav1d\n";
|
|
|
|
|
afronaut wrote:
but in C# you cannot say:
string x = new DateTime().Now.ToString();
Now is a static property of the DateTime class. When getting the property, a DateTime instance is created for you, so no need to do it again. Tip: think of as just another construtor (like many other static methods that also returns an instance of a class) with a meaningful name. Now, that sound a lot better than just DateTime() , but it adds meaning to the object.
Hope this helps
Before you criticize a man, walk a mile in his shoes. That way, when you do criticize him, you'll be a mile away and have his shoes.
|
|
|
|
|
I just find it intriguing that VB.NET allows access to static members via *instance* variables. Actually, it's not really intriguing, it's just *wrong*.
*->>Always working on my game, teach me
*->>something new.
cout << "dav1d\n";
|
|
|
|
|