开发者

How to prevent console from being displayed when using VLC's dummy interface

开发者 https://www.devze.com 2023-03-06 02:17 出处:网络
I\'m trying to launch VLC in \"dummy\" mode from a Node.js server script, however using child_process.spawn(\'vlc\',[\'-I dummy\']) produces a new console window for VLC\'s output when using Windows.

I'm trying to launch VLC in "dummy" mode from a Node.js server script, however using child_process.spawn('vlc',['-I dummy']) produces a new console window for VLC's output when using Windows. Is there a way to prevent this happening and force all stdout though the stdout ReadableStream so no "popup windows" occur?

EDIT: This problem had nothing to do with node.js, it was simply the way I was calling it and VLC's behavi开发者_如何学Goour. The solution is below.

Thanks.


I found a solution for the specific problem:

VLC has a command line option to surpress this window --*-quiet where * is the interface.

e.g. For the dummy interface, use

child_process.spawn('vlc',['-I dummy','--dummy-quiet'])

For the rc interface, use

child_process.spawn('vlc',['-I rc','--rc-quiet'])


I would like to complement Adam M-W answer.

VLC has a command line option to suppress this window --*-quiet where * is the interface.

e.g. For the dummy interface, use

child_process.spawn('vlc',['-I dummy','--dummy-quiet']) For the rc interface, use

child_process.spawn('vlc',['-I rc','--rc-quiet'])

answered Jun 13 '11 at 14:12 Adam M-W

at least on my system, VLC now sends its messages to stdError, so this is the channel which needs to be monitored.

My interface is with Qt , QtProcess and these are the options that worked for me.

Using MergedChannels and reading stdOut.

m_proc->setProcessChannelMode(QProcess::MergedChannels);
connect (m_proc,SIGNAL(readyReadStandardOutput()),
           this, SLOT(readyRead()));

void ReDirVLC::readyRead(){
    if (!m_proc) return;
    qDebug()<<m_proc->readAllStandardOutput() << endl;
}

Using SeparateChannels and reading stdError

m_proc->setProcessChannelMode(QProcess::SeparateChannels);
connect (m_proc,SIGNAL(readyReadStandardError()),
           this, SLOT(readyRead()));

void ReDirVLC::readyRead(){
    if (!m_proc) return;
    qDebug()<<m_proc->readAllStandardError() << endl;
}


Maybe you could run the process with child_process.spawn('start', ['/b', 'vlc', '-I dummy']) instead?

0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号