VoxCommando

Help and Support (Using VoxCommando) => VoxCommando Basics and Core Features => Topic started by: SteveB69 on January 01, 2016, 11:09:40 PM

Title: OSD Display Time
Post by: SteveB69 on January 01, 2016, 11:09:40 PM
I was wondering if there is a way to reduce the amount of time the OSD stays on screen for, looked al over the options but can't find anything.
Title: Re: OSD Display Time
Post by: PegLegTV on January 02, 2016, 02:19:40 AM
In this command I have it show an OSD for 5000 milliseconds (5 seconds)

in the action the second parameter is used for duration and the third parameter is used for position

if you hover your mouse over each of the parameters (empty boxes next to the command) for an action it will give you a description what they can be used for, also if you open the action selection tree (the magic wand Icon next to the action) it will give you a description of what each action and parameter can do or you can look here: http://voxcommando.com/mediawiki/index.php?title=Actions

Code: [Select]
<?xml version="1.0" encoding="utf-16"?>
<!--VoxCommando 2.2.1.4-->
<command id="361" name="show OSD for X time" enabled="true" alwaysOn="False" confirm="False" requiredConfidence="0" loop="False" loopDelay="0" loopMax="0" description="">
  <action>
    <cmdType>OSD.ShowText</cmdType>
    <params>
      <param>Hello SteveB69</param>
      <param>5000</param>
    </params>
    <cmdRepeat>1</cmdRepeat>
  </action>
</command>

I know this can seem over whelming, but I'm self taught with this very program, it takes a little while to get a hold of things but the nice part about this program is that jitterjames and nimester do a GREAT job with the documentation and videos you just have to read through it and watch a lot of videos and experiment and you will get there
Title: Re: OSD Display Time
Post by: SteveB69 on January 02, 2016, 02:26:22 AM
Thanks for the reply PegLegTV.

I've dropped the code you posted in, changed the milliseconds to 1000, what now? Restarted VC & the OCD when confirming commands is still on screen for around 10 secs.

Maybe you mis understood, I'm talking about the overall OSD that confirms every command, I know it can be turned off but I'd like it on, just not for 10 seconds??
Title: Re: OSD Display Time
Post by: PegLegTV on January 02, 2016, 02:38:25 AM
sorry about that, I didn't realize you where talking about the OSD used for confirming commands. are you talking about the option in the options menu "Show OSD on Command" or are you talking about when you select "Must Confirm" inside a command?
Title: Re: OSD Display Time
Post by: SteveB69 on January 03, 2016, 07:42:14 PM
I have show OSD on command & only show OSD display if command is executed checked.
I don't use the Must Confirm command at the moment.

I'd like a 1 second or so showing of the OSD??
Title: Re: OSD Display Time
Post by: jitterjames on January 03, 2016, 10:17:52 PM
When a command is recognized the osd that is shown will be there for a brief period which is fixed and cannot be changed by the user.
Title: Re: OSD Display Time
Post by: SteveB69 on January 03, 2016, 10:21:33 PM
Ahh ok, my OSD is about 10 seconds...
Title: Re: OSD Display Time
Post by: jitterjames on January 04, 2016, 01:18:37 PM
The OSD normally shows for 6 seconds (not 10), and then fades out quickly.  If it takes longer than that, it is because VC is frozen or busy for some reason.  That may depend on what your macro is doing.  If you use TTS.SpeakSync for example, and the speech takes more than 6 seconds to complete that may prevent the OSD from disappearing after 6 seconds.  In that case it should disappear when the speaking is finished.
Title: Re: OSD Display Time
Post by: Voxy on October 20, 2016, 01:57:32 PM
I find the OSD very useful to get information about pronunciation, similar/conflicts between commands and so on but with the current implementation I can't use it because it's often in the way staying on for to long (6 seconds plus fade out time).
To make the OSD option usable for me I think it would need a setting for time out.

Is there any chance getting this needed and useful setting in Options or at least have OSD disappear after 2 seconds plus a quicker fade out?

Please, please,  please!
Title: Re: OSD Display Time
Post by: jitterjames on October 20, 2016, 03:21:49 PM
I assume you are talking about the automatic OSD for recognized commands confidence and alternates, and not the OSD actions for custom messages?

I find the timing a perfect balance to allow time for unhurried reading, but without staying onscreen for too long.  That said, an option to adjust the timeout is something I will consider adding.  I just prefer not to clutter the options form with too much stuff.  It is already very full.
Title: Re: OSD Display Time
Post by: Voxy on October 22, 2016, 11:21:17 AM
Sorry for my harsh and rude phrasing in my previous post (now edited).

Yes, my OSD time out setting feature request is regarding the automatic OSD for recognized commands confidence and alternates.

Since my post I've been working on finding a way to use actions to achieve what I want.
Perhaps that possibility is already there although I don't quite manage to achieve what I want, an automatic OSD with customizable timeout setting.

Firstly I can't get the command to get triggered by every voice command.
I tried dragging the megaphone icon from the history but it doesn't get accepted as an event.
Activating VC.Alternates in Options - OSD I can use these events but they only occur for voice commands when there are Alternates  but I also would like to get voice commands without alternates in an OSD to verify it was interpreted as intended.

Secondly I can't find a variable-parameter for Alternates to be put as/in the text message.


To display the OSD message I've tried three different actions:

* The Growl plugin doesn´t have any timeout setting as an Action Parameter in VC but in the Growl Application settings for Application - Voxcommando you have quite a few settings including Sticky which means stay visible until clicked and even without Sticky set to on you can keep the balloon window visible by putting the mouse pointer over it.
Unfortunately the shortest TimeOut in Growl is setting is 3 seconds which is ok and less than half of the timeout length for VC Automatic OSD but I would prefer 1-2 seconds.

* OSD.ShowText worked ok but I miss settings to control or turn off fade out.

* VcAdvanced.Notify work well but it's timeout setting didn't have any effect on my Windows 7 computer, it was 4 seconds no matter what number for milliseconds I set.
For me, I prefer the VC Growl plugin over VcAdvanced.Notify.

(On a side note/a tip: the Growl application has it's own Windows plugin that shows all Windows balloon notifications through Growl giving you a lot of settings like layou, position, timeout, for balloon notifications from any application, even from those without any built-in Growl plugin/feature.)


The basic and important parts that I can´t get to work is how to get the command to get triggered by every voice command and
how to get Alternates to be put as/in the text message.

Does anyone have any ideas or suggestions for how to fix/where to find the missing parts to make automatic OSD work by using actions and events?

@jitterjames regarding having to many settings in options;
Perhaps a Basic + Advanced layout could solve this problems, only the basic more fundamental settings in Basic View and the more optional, advanced fine tuning settings in an Advanced View?
Title: Re: OSD Display Time
Post by: nime5ter on October 22, 2016, 01:48:39 PM
You can use the OSD events Python script already posted on the forum (http://voxcommando.com/forum/index.php?topic=1689.msg14689#msg14689).

If you're not already using the Python plugin you'll need to activate it. The script should be saved locally and then loaded once when VC first launches. We usually do that using a command something like this. In this case, I saved the script as "osdEvents.py" and placed it in a PY subfolder that I created, directly within my main VC folder (this is not the PY plugin folder within \plugins):

Code: [Select]
<?xml version="1.0" encoding="utf-16"?>
<!--VoxCommando 2.2.3.0-->
<command id="55" name="load OSD events python file" enabled="true" alwaysOn="False" confirm="False" requiredConfidence="0" loop="False" loopDelay="0" loopMax="0" description="">
  <action>
    <cmdType>PY.ExecFile</cmdType>
    <params>
      <param>PY\osdEvents.py</param>
    </params>
    <cmdRepeat>1</cmdRepeat>
  </action>
  <event>VC.Loaded</event>
</command>

Once the script is loaded, a VC.Reco event will be generated each time a command is recognized.

The VC.Reco event includes 6 payloads, if you use the script as it is currently written:

1. The phrase you said that was recognized (equivalent to the variable {LastSpoken})
2. The command name (as listed in your command tree)
3. The command group name
4. The confidence value
5. Whether the speech understood passed the confidence value (true or false)
6. Whether the command was executed (true or false)
Title: Re: OSD Display Time
Post by: Voxy on October 22, 2016, 04:41:27 PM
Thank you very much nime5ter. This solution fills almost all my OSD needs, the only thing missing is the Alternates.
Thanks to your tip I also learned and understood much more about Events and them saving information to variables.

Both the event VC.Reco and the event VC.Alternates save data to variables. When I then recall variable {1} I get the variable data {1} from both events.
Do you know any way to distinguish  between them. Is it perhaps possible by recalling the variables in a more precise way like {(VC.Reco)1} and {(VC.Alternates.6)1} ?
Title: Re: OSD Display Time
Post by: jitterjames on October 22, 2016, 04:45:02 PM
I think you are talking about payloads.  It's good to call them by their proper name in order to avoid confusion, because variable means something specific in VoxCommando, or is just kind of vague when used as a general term.

In VoxCommando payloads can only be accessed by number {1}, {2} etc.

I believe alternates are also accessible from python, but if you're happy with the look of the OSD display in VoxCommando you may just want to wait for the next release.  I will add an option to change the display time.
Title: Re: OSD Display Time
Post by: Voxy on October 22, 2016, 06:19:31 PM
I'm talking about the data 1-6 in nime5ters image attached to this post.
Which is the correct term for them?

I have also attached a Group with the Command I am experimenting with. Perhaps my questions gets clearer when you look at it.
While experimenting and trying it out I have put all parts in separate messages but I plan to combine them in fewer or one message when/if I get everything to work with Alternates.

Now that I have found Growl and if there is a way to get hold of the Alternates and put them in messages I think that alternative would be more interesting for me then to start to use the built-in automatic OSD with timeout setting.
Even though Growl's minimum 3 seconds timeout is a little bit long for me it has got many nice features that make me tolerate this and I can close Messageboxes before the timeout just by clicking on them. I can also keep them open by holding the mouse pointer over them.
Also, with the Growl solution users can choose which information they want in the popup message boxes.

If, however, there isn't any way to get hold of the Alternates and put them in Growl messages the automatic OSD with timeout setting  would be very useful for me for showing the Alternates, and perhaps also even though there would be be a solution for showing the Alternates in Growl messages.
Title: Re: OSD Display Time
Post by: jitterjames on October 22, 2016, 06:31:34 PM
Yes those are called payloads.

Here is the Python which will add a 7th payload that is the alternates, and I've separated the alternates using \r\n (new line) but you could change the Python to just use a comma if you wanted to.

Sorry the structure of the OSD object is undocumented at this point.  It was originally intended to be used directly by plugins written in C# and in that context it is somewhat documented for the developer.  One of the elements of OSD event object is a list of strings, named alternateSpeech.

so I added the line:    strAlts = '\r\n'.join(osdInfo.alternateSpeech)
and then included the variable strAlts in the list of payloads when calling  vc.triggerEvent.

Code: [Select]
from System.Collections.Generic import *

def osdEvent(osdInfo):   
    strText = unicode(osdInfo.speechText)   
    strCommandName = unicode(osdInfo.commandName)
    strGroup = str(osdInfo.groupName)
    strConfidence= str(osdInfo.confidence)
    strPass = str(osdInfo.confidencePassed)
    strDoingCommand=str(osdInfo.doingCommand)
    strAlts = unicode('\r\n'.join(osdInfo.alternateSpeech))

vc.OnOSD -= osdEvent
vc.OnOSD += osdEvent

I haven't looked at your commands yet, but ultimately if you are going to send this to Growl, it would be better to send it directly from the Python plugin in order to reduce the amount of work VC has to do every time it hears a voice command.  This is actually the reason I don't create events for recognized speech, because I think it would just be too much overhead on top of whatever else VC is supposed to do with your voice command when it's recognized.
Title: Re: OSD Display Time
Post by: nime5ter on October 23, 2016, 01:15:22 PM
I'm talking about the data 1-6 in nime5ters image attached to this post.
Which is the correct term for them?

Maybe the wiki entry can help clarify: http://voxcommando.com/mediawiki/index.php?title=Payloads

The documentation on Events also has a bit of information on events with payloads: http://voxcommando.com/mediawiki/index.php?title=Events
Title: Re: OSD Display Time
Post by: nime5ter on October 23, 2016, 02:02:23 PM
I have also attached a Group with the Command I am experimenting with. Perhaps my questions gets clearer when you look at it.
While experimenting and trying it out I have put all parts in separate messages but I plan to combine them in fewer or one message when/if I get everything to work with Alternates.

Right now you are triggering the same command using multiple different events. Since VC.Reco will be generated with every recognized commands, you have the same VC command being triggered twice when there are alternates--once via the Alternates event and then again via the VC.Reco event.

The simplest solution is to create 2 commands. One that is triggered by the VC.Reco event, and a different command that is triggered by the VC.Alternates events.

Something like the following command could be used to send all alternates to Growl:
Code: [Select]
<?xml version="1.0" encoding="utf-16"?>
<!--VoxCommando 2.2.3.0-->
<command id="340" name="Growl Notifications (Alternates)" enabled="true" alwaysOn="False" confirm="False" requiredConfidence="0" loop="False" loopDelay="10" loopMax="{#P}" description="{#P}==number of payloads. If there are 7 alternates, we loop 7 times. Each time, the value for {j} increases by one. I add a brief pause here just in case Growl requires it. You can try without it.">
  <loop>
    <loopParams>
      <from>1</from>
      <to>{#P}</to>
    </loopParams>
    <loopActions>
      <action>
        <cmdType>Growl.Send</cmdType>
        <params>
          <param>alternate {j}</param>
          <param>{{j}}</param>
        </params>
        <cmdRepeat>1</cmdRepeat>
      </action>
      <action>
        <cmdType>VC.Pause</cmdType>
        <params>
          <param>100</param>
        </params>
        <cmdRepeat>1</cmdRepeat>
      </action>
    </loopActions>
  </loop>
  <event>VC.Alternates.*</event>
</command>

A few additional notes:

1) I see that you have tried to set the VC.Alternates events to "optional", as we do for phrases. Events don't work quite the same way as voice phrases. There is no such thing as an optional event, to my knowledge.

You can't build a "combination trigger" by dragging different events onto a command. Instead, each event will separately trigger the command.

(It would be better if the UI didn't permit you to set events to "optional" because it's technically meaningless. This is probably something we can change in an upcoming release.)

2) As you can see in the above command example, rather than separately attaching each VC.Alternates event to your command, you can use the * wildcard. This means that any event that starts with VC.Alternates to trigger the command.

http://voxcommando.com/mediawiki/index.php?title=Events#Using_event_triggers

3) My solution above does not address your desire to have all of the information combined into one message. But I think it's a good idea for you to start with this in order to see how it works.

---
All of the above does not change James's point that if you want to send information to Growl for every single command, it would be more efficient to use a Python-only solution.

In a Python-only solution, you would not generate a VC.Reco event in your script using VC.TriggerEvent and then execute VC commands with that event.

You would instead string all the different pieces of information together in your script, and then send the relevant notifications directly to Growl within the script.

However, if you're still learning how to use VC, experimenting with my suggestion above is a good starting point. Later you can look into adapting the Python script once you've decided how you want Growl to behave.

Title: Re: OSD Display Time
Post by: Voxy on October 23, 2016, 02:52:52 PM
Yes those are called payloads.

Here is the Python which will add a 7th payload that is the alternates, and I've separated the alternates using \r\n (new line) but you could change the Python to just use a comma if you wanted to.

Sorry the structure of the OSD object is undocumented at this point.  It was originally intended to be used directly by plugins written in C# and in that context it is somewhat documented for the developer.  One of the elements of OSD event object is a list of strings, named alternateSpeech.

so I added the line:    strAlts = '\r\n'.join(osdInfo.alternateSpeech)
and then included the variable strAlts in the list of payloads when calling  vc.triggerEvent.

Code: [Select]
from System.Collections.Generic import *

def osdEvent(osdInfo):   
    strText = unicode(osdInfo.speechText)   
    strCommandName = unicode(osdInfo.commandName)
    strGroup = str(osdInfo.groupName)
    strConfidence= str(osdInfo.confidence)
    strPass = str(osdInfo.confidencePassed)
    strDoingCommand=str(osdInfo.doingCommand)
    strAlts = unicode('\r\n'.join(osdInfo.alternateSpeech))

vc.OnOSD -= osdEvent
vc.OnOSD += osdEvent

I haven't looked at your commands yet, but ultimately if you are going to send this to Growl, it would be better to send it directly from the Python plugin in order to reduce the amount of work VC has to do every time it hears a voice command.  This is actually the reason I don't create events for recognized speech, because I think it would just be too much overhead on top of whatever else VC is supposed to do with your voice command when it's recognized.

Oh yeah, now the solution is complete! Thank you very much nime5ter and jitterjames!

This solution to my feature request is much better and much more flexible and useful to me than what I asked for.
I guess this solution also could be satisfying to SteveB69 who started this thread.

I'm not surprised that there existed a solution because Voxcommando is a very cleverly designed application with lots of possibilities, flexibility and customizability and even though Voxcommando is a very powerful application it is at the same time not very difficult to learn and understand. Many applications are either powerful or easy to understand, Voxcommando is both.

After a computer reboot the timeout/duration parameter for the OSD.ShowText started to work correctly on my computer which gives me even more freedom to choose which Action I want to use for my automatic OSD setup.
I can choose to use OSD.ShowText Action if I want shorter timeout length than 3 seconds or I can choose to use Growl Action if I want it's extra features.

I love Voxcommando's high level of possibilities and customizability.
If there's a downside with a solution or when using a feature for me it's better to be given the information about the downside and then myself decide if the downside is worth paying to get the feature rather than all possible solutions is not presented/given to me.
In this case, about creating events for recognized speech perhaps adding to much overhead, for me I would have preferred a setting in Options to be able to turn on creating events for recognized speech if I needed it and then see how it affected my computer. If I would find it had to great negative impact on my computer I could just turn off these events again.
These kind of advanced settings could be put in a special section in options called Advanced.

About me confusing Payloads with variables I will try to get to understand the difference but it's really, really difficult and confusing for me to understand why Payloads aren't variables.
When the wiki about Payloads says;
"These placeholders are then replaced in the command's macro by the values we provide when we issue our voice commands (or through event payloads)."
it makes it even harder for me to understand that payloads are not variables. But I'm no programmer so perhaps I have misunderstood what variables are.
Regardless if I will manage to understand it or not I'll try to use the terms correctly in the future. Thanks for the links nime5ters.
Title: Re: OSD Display Time
Post by: Voxy on October 23, 2016, 02:59:43 PM
Right now you are triggering the same command using multiple different events. Since VC.Reco will be generated with every recognized commands, you have the same VC command being triggered twice when there are alternates--once via the Alternates event and then again via the VC.Reco event.

The simplest solution is to create 2 commands. One that is triggered by the VC.Reco event, and a different command that is triggered by the VC.Alternates events.

Something like the following command could be used to send all alternates to Growl:
Code: [Select]
<?xml version="1.0" encoding="utf-16"?>
<!--VoxCommando 2.2.3.0-->
<command id="340" name="Growl Notifications (Alternates)" enabled="true" alwaysOn="False" confirm="False" requiredConfidence="0" loop="False" loopDelay="10" loopMax="{#P}" description="{#P}==number of payloads. If there are 7 alternates, we loop 7 times. Each time, the value for {j} increases by one. I add a brief pause here just in case Growl requires it. You can try without it.">
  <loop>
    <loopParams>
      <from>1</from>
      <to>{#P}</to>
    </loopParams>
    <loopActions>
      <action>
        <cmdType>Growl.Send</cmdType>
        <params>
          <param>alternate {j}</param>
          <param>{{j}}</param>
        </params>
        <cmdRepeat>1</cmdRepeat>
      </action>
      <action>
        <cmdType>VC.Pause</cmdType>
        <params>
          <param>100</param>
        </params>
        <cmdRepeat>1</cmdRepeat>
      </action>
    </loopActions>
  </loop>
  <event>VC.Alternates.*</event>
</command>

A few additional notes:

1) I see that you have tried to set the VC.Alternates events to "optional", as we do for phrases. Events don't work quite the same way as voice phrases. There is no such thing as an optional event, to my knowledge.

You can't build a "combination trigger" by dragging different events onto a command. Instead, each event will separately trigger the command.

(It would be better if the UI didn't permit you to set events to "optional" because it's technically meaningless. This is probably something we can change in an upcoming release.)

2) As you can see in the above command example, rather than separately attaching each VC.Alternates event to your command, you can use the * wildcard. This means that any event that starts with VC.Alternates to trigger the command.

http://voxcommando.com/mediawiki/index.php?title=Events#Using_event_triggers

3) My solution above does not address your desire to have all of the information combined into one message. But I think it's a good idea for you to start with this in order to see how it works.

---
All of the above does not change James's point that if you want to send information to Growl for every single command, it would be more efficient to use a Python-only solution.

In a Python-only solution, you would not generate a VC.Reco event in your script using VC.TriggerEvent and then execute VC commands with that event.

You would instead string all the different pieces of information together in your script, and then send the relevant notifications directly to Growl within the script.

However, if you're still learning how to use VC, experimenting with my suggestion above is a good starting point. Later you can look into adapting the Python script once you've decided how you want Growl to behave.

nime5ter: thanks for looking at and commenting my Command. It was just a kind of laboratory trying to guess and figure out how different things works by trial and error without having enough knowledge nor information.
After jitterjames put the Alternates as a variable in the python script I don't need to use the VC.alternates events any longer.
I've attached the command I made after jitterjames updated the python script. At the momentI have both OSD.ShowText and Growl.Send doing the same thing to compare them and see which one I prefer.
I'll examine and try out your Command later, I always learn something new looking at and trying the Commands you make.
Title: Re: OSD Display Time
Post by: nime5ter on October 23, 2016, 03:33:11 PM
About me confusing Payloads with variables I will try to get to understand the difference but it's really, really difficult and confusing for me to understand why Payloads aren't variables.

:) Mea culpa. That is because I created the documentation. When programmers try to explain what a payload is, no one understands them. I tried to explain payloads in a way that makes sense to non-programmers so that our users can get more comfortable using them.

I know James would prefer if I avoided using the same kind of language to describe payloads and variables.

Real programmers consider payloads to be a discrete concept. A payload in the real world is an item that is transported and passed along from one place to the next. So, a truck that is transporting 500 kilos of tomatoes is carrying a 500 kg payload. The payload is not part of the truck: the truck can travel without it, but the whole reason the truck is traveling is to carry those tomatoes to a destination.

"Payload" is a more concise way of describing the parcels of information that we pass to a command when triggering the command.

It is certainly easier for us to help users on the forum when queries are expressed as concisely as possible.
Title: Re: OSD Display Time
Post by: jitterjames on October 24, 2016, 02:13:36 PM
* VcAdvanced.Notify work well but it's timeout setting didn't have any effect on my Windows 7 computer, it was 4 seconds no matter what number for milliseconds I set.
For me, I prefer the VC Growl plugin over VcAdvanced.Notify.


Microsoft, in their wisdom have decided to ignore the duration specified by programmers in Windows 7 and later, in order to make everyone feel safe and happy. 
Thanks again MS!  ::dis
Title: Re: OSD Display Time
Post by: Voxy on October 24, 2016, 05:29:28 PM
Microsoft, in their wisdom have decided to ignore the duration specified by programmers in Windows 7 and later, in order to make everyone feel safe and happy. 
Thanks again MS!  ::dis

I read somewhere that the minimum timeout for tray notifications in Windows is 5 seconds.
Somehow Growl manage to set it shorter anyway but has chosen to not offer shorter timeout than 3 seconds.
For shorter OSD timeout than 3 seconds I can use OSD.ShowText but OSD.ShowText can interfere with some other overlay windows/dialogues.
Title: Re: OSD Display Time
Post by: jitterjames on October 24, 2016, 05:38:06 PM
Yes, that is correct, but it is set by the user and 5 seconds is the default.

I could be wrong but I don't think that growl uses the windows notification system at all and instead creates its own popups.
Title: Re: OSD Display Time
Post by: nime5ter on October 26, 2016, 05:55:18 PM
Microsoft, in their wisdom have decided to ignore the duration specified by programmers in Windows 7 and later, in order to make everyone feel safe and happy. 
Thanks again MS!  ::dis

As of the beta release of VC version 2.2.3.0 today, users can now set a duration of less than 5 seconds when using the action VCadvanced.Notify (http://voxcommando.com/mediawiki/index.php?title=Actions#Notify). Please note that the fix is experimental. You can try it, but we can't guarantee it will work on every system.

Change log: http://voxcommando.com/mediawiki/index.php?title=ChangeLog#Version_2.2.3.0

Beta can be downloaded on the Downloads page: http://voxcommando.com/home/downloads/
Title: Re: OSD Display Time
Post by: nime5ter on October 28, 2016, 09:36:05 AM
I was wondering if there is a way to reduce the amount of time the OSD stays on screen for, looked al over the options but can't find anything.

As of beta release VC 2.2.3.0, there is a new setting in Options—"OSD display time"—permitting users to set the amount of time that the automated OSD messages stay on the screen (e.g., recognized commands or alternates, if these OSD message options are selected).

Change log: http://voxcommando.com/mediawiki/index.php?title=ChangeLog#Version_2.2.3.0

Latest beta version is available on the Downloads page: http://voxcommando.com/home/downloads/