Solved

VB Word control

Posted on 2002-03-21
8
163 Views
Last Modified: 2010-05-02
Fom VB I launch a word document and run a macro within that document.  The macro can take some time,  how do I give my VB application back control after I launch the word document.  The application doesn't really care if the word macro completes or fails.  Currently, the VB app has to wait for word to complete before control can be given.

Dim objNewDoc
Set objNewDoc = oWord.Documents.Add(WORKING_DIR & _ "\templates\" & s_reportlocation)

oWord.Visible = True


objNewDoc.PopulateDocument
         
Unload Me
   
'Kill all of the word related objects
Set objNewDoc = Nothing
Set oWord = Nothing
0
Comment
Question by:srobia
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
8 Comments
 
LVL 1

Expert Comment

by:COAtheGREAT
ID: 6885560
Try using the timer in macro. Wen you call the function it enabled timer control so you get out of function, and on timer event you do what you need.
0
 

Author Comment

by:srobia
ID: 6885565
I'm not sure I know what you mean -- how would I launch the macro to do the program?  Or would I call the timer macro and in the timer macro launch the other macro?
0
 
LVL 1

Expert Comment

by:COAtheGREAT
ID: 6885641
You can insert UserForm in word document and plase on it timer control. On timer event do jour work. Your word macro just enables timer.
0
Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
LVL 44

Expert Comment

by:bruintje
ID: 6886120
Hi srobia, instead of creating the process like that, for background processing i would use the shell command

http://support.microsoft.com/default.aspx?scid=kb;EN-US;q129796

word has some commandline switches and one of tehm is to start with a macro /m + macroname so for example WORKING_DIR & _ "\templates\" & s_reportlocation & " /m" & PopulateDocument

HTH:O)Bruintje
0
 

Author Comment

by:srobia
ID: 6886760
bruintje -- I like the idea -- and I tried it.  However, I need to populate bookmarks from the VB application.  So unfortunately, I need to be able to launch word with a reference for the VB app to call and populate bookmarks.

COAtheGREAT -- can you give an example -- I think I understand I just want to make sure.  Thanks,
0
 
LVL 1

Expert Comment

by:COAtheGREAT
ID: 6886898
I am afraid i wos wrong i cant find the timer in word, but try to use idea if you can. Or you can use win api but it is harder way because you must create threed.
0
 
LVL 49

Expert Comment

by:DanRollins
ID: 7634218
Hi srobia,
It appears that you have forgotten this question. I will ask Community Support to close it unless you finalize it within 7 days. I will ask a Community Support Moderator to:

    Refund points and save as a 0-pt PAQ.

srobia, Please DO NOT accept this comment as an answer.
EXPERTS: Post a comment if you are certain that an expert deserves credit.  Explain why.
==========
DanRollins -- EE database cleanup volunteer
0
 
LVL 1

Accepted Solution

by:
kodiakbear earned 0 total points
ID: 7666093
Moving to the Paq

kb
Experts Exchange Moderator
0

Featured Post

Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

There are many ways to remove duplicate entries in an SQL or Access database. Most make you temporarily insert an ID field, make a temp table and copy data back and forth, and/or are slow. Here is an easy way in VB6 using ADO to remove duplicate row…
Enums (shorthand for ‘enumerations’) are not often used by programmers but they can be quite valuable when they are.  What are they? An Enum is just a type of variable like a string or an Integer, but in this case one that you create that contains…
As developers, we are not limited to the functions provided by the VBA language. In addition, we can call the functions that are part of the Windows operating system. These functions are part of the Windows API (Application Programming Interface). U…
Get people started with the process of using Access VBA to control Outlook using automation, Microsoft Access can control other applications. An example is the ability to programmatically talk to Microsoft Outlook. Using automation, an Access applic…

726 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question