web-dev-qa-db-ja.com

マイクとラインを同時に、痛みを伴わずに録音する最も簡単な方法は?

Arch-linuxをalsa、pulseaudio、pavucontrol、jackなどで使用しています。どんなに低音でもマイクとギターを同時に録音したいです。 2つのチャンネルを一方のチャンネルのリアマイクにリンクし、もう一方のチャンネルにラインインしてモニターまたは接続ジャックシンクに接続する仮想パルスオーディオシンクを作成する方法についての投稿がいくつかありますが、現在の設定では何も意味がありません。私のdefault.paファイルは

     #!/usr/bin/pulseaudio -nF
     #
     # This file is part of PulseAudio.
     #
     # PulseAudio is free software; you can redistribute it and/or modify it
     # under the terms of the GNU Lesser General Public License as published by
     # the Free Software Foundation; either version 2 of the License, or
     # (at your option) any later version.
     #
     # PulseAudio is distributed in the hope that it will be useful, but
     # WITHOUT ANY WARRANTY; without even the implied warranty of
     # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
     # General Public License for more details.
     #
     # You should have received a copy of the GNU Lesser General Public License
     # along with PulseAudio; if not, see <http://www.gnu.org/licenses/>.

     # This startup script is used only if PulseAudio is started per-user
     # (i.e. not in system mode)

     .fail

     ### Automatically restore the volume of streams and devices
     load-module module-device-restore
     load-module module-stream-restore
     load-module module-card-restore

     ### Automatically augment property information from .desktop files
     ### stored in /usr/share/application
     load-module module-augment-properties

     ### Should be after module-*-restore but before module-*-detect
     load-module module-switch-on-port-available

     ### Load audio drivers statically
     ### (it's probably better to not load these drivers manually, but instead
     ### use module-udev-detect -- see below -- for doing this automatically)
     #load-module module-alsa-sink
     #load-module module-alsa-source device=hw:1,0
     #load-module module-oss device="/dev/dsp" sink_name=output source_name=input
     #load-module module-oss-mmap device="/dev/dsp" sink_name=output source_name=input
     #load-module module-null-sink
     #load-module module-pipe-sink

     ### Automatically load driver modules depending on the hardware available
     .ifexists module-udev-detect.so
     load-module module-udev-detect
     .else
     ### Use the static hardware detection module (for systems that lack udev support)
     load-module module-detect
     .endif

     ### Automatically connect sink and source if JACK server is present
     .ifexists module-jackdbus-detect.so
     .nofail
     load-module module-jackdbus-detect channels=2
     .fail
     .endif

     ### Automatically load driver modules for Bluetooth hardware
     .ifexists module-bluetooth-policy.so
     load-module module-bluetooth-policy
     .endif

     .ifexists module-bluetooth-discover.so
     load-module module-bluetooth-discover
     .endif

     ### Load several protocols
     .ifexists module-esound-protocol-unix.so
     load-module module-esound-protocol-unix
     .endif
     load-module module-native-protocol-unix

     ### Network access (may be configured with paprefs, so leave this commented
     ### here if you plan to use paprefs)
     #load-module module-esound-protocol-tcp
     #load-module module-native-protocol-tcp
     #load-module module-zeroconf-publish

     ### Load the RTP receiver module (also configured via paprefs, see above)
     #load-module module-rtp-recv

     ### Load the RTP sender module (also configured via paprefs, see above)
     #load-module module-null-sink sink_name=rtp format=s16be channels=2 rate=44100 sink_properties="device.description='RTP Multicast Sink'"
     #load-module module-rtp-send source=rtp.monitor

     ### Load additional modules from GConf settings. This can be configured with the paprefs tool.
     ### Please keep in mind that the modules configured by paprefs might conflict with manually
     ### loaded modules.
     .ifexists module-gconf.so
     .nofail
     load-module module-gconf
     .fail
     .endif

     ### Automatically restore the default sink/source when changed by the user
     ### during runtime
     ### NOTE: This should be loaded as early as possible so that subsequent modules
     ### that look up the default sink/source get the right value
     load-module module-default-device-restore

     ### Automatically move streams to the default sink if the sink they are
     ### connected to dies, similar for sources
     load-module module-rescue-streams

     ### Make sure we always have a sink around, even if it is a null sink.
     load-module module-always-sink

     ### Honour intended role device property
     load-module module-intended-roles

     ### Automatically suspend sinks/sources that become idle for too long
     load-module module-suspend-on-idle

     ### If autoexit on idle is enabled we want to make sure we only quit
     ### when no local session needs us anymore.
     .ifexists module-console-kit.so
     load-module module-console-kit
     .endif
     .ifexists module-systemd-login.so
     load-module module-systemd-login
     .endif

     ### Enable positioned event sounds
     load-module module-position-event-sounds

     ### Cork music/video streams when a phone stream is active
     load-module module-role-cork

     ### Modules to allow autoloading of filters (such as echo cancellation)
     ### on demand. module-filter-heuristics tries to determine what filters
     ### make sense, and module-filter-apply does the heavy-lifting of
     ### loading modules and rerouting streams.
     load-module module-filter-heuristics
     load-module module-filter-apply

     ### Make some devices default
     #set-default-sink output
     #set-default-source input

たとえば、私はこのbashスクリプトが最初のスクリプトを実行することを発見しました。

     #!/bin/bash

     #    Script to map two pulseaudio hardware input sources as mono inputs
     #    to left and right channel of a new loopback-sink respectively. This
     #    sink can be used e.g. to use VoIP or record two microphones seperately.
     #    Copyright (C) 2013, Henning Hollermann, [email protected]
     #
     #    This program is free software: you can redistribute it and/or modify
     #    it under the terms of the GNU General Public License as published by
     #    the Free Software Foundation, either version 3 of the License, or
     #    (at your option) any later version.
     #
     #    This program is distributed in the hope that it will be useful,
     #    but WITHOUT ANY WARRANTY; without even the implied warranty of
     #    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     #    GNU General Public License for more details.
     #
     #    You should have received a copy of the GNU General Public License
     #    along with this program.  If not, see <http://www.gnu.org/licenses/>.

     do_activate() {
         while [ "x" = "x$LEFT" ]; do
             echo "Choose Source for left channel by ID"
             pactl list short sources
             read ID
             LEFT=$(pactl list short sources|awk '/^'$ID'/{print $2}')
         done
         while [ "x" = "x$RIGHT" ]; do
             echo "Choose Source for right channel by ID"
             pactl list shrot sources | grep -v $LEFT
             read ID
             RIGHT=$(pactl list short sources | grep -v $LEFT|awk '/^'$ID'/{print $2}')
         done
         # Create the name of the Combined sink
         NAME="Combined_Mics:_Left:_"$(echo $LEFT|awk -F'.' '$0=$2')"_Right:_"$(echo $RIGHT|awk 
     -F'.' '$0=$2')

         echo "[LOAD] null sink as \"$NAME\" to connect the two mics to"
         pactl load-module module-null-sink \
                 sink_name=combined channels=2 \
                 sink_properties="device.description=$NAME"

         echo "[LOAD] map source 1 ($LEFT) to left channel of \"$NAME\""
         pactl load-module module-remap-source \
                 source_name=${LEFT}_left_channel master=$LEFT channels=2 \
                 master_channel_map=mono,mono channel_map=left,left
         pactl load-module module-loopback sink=combined source=${LEFT}_left_channel

         echo "[LOAD] map source 2 ($RIGHT) to right channel of \"$NAME\""
         pactl load-module module-remap-source \
                 source_name=${RIGHT}_right_channel master=$RIGHT channels=2 \
                 master_channel_map=mono,mono channel_map=right,right
         pactl load-module module-loopback sink=combined source=${RIGHT}_right_channel
         echo "[DONE] Now adjust the left and right channel volume of the new sink to be equally 
     loud"
     }

     do_deactivate() {
         echo "[UNLOAD] pulseaudio modules..."
         echo "[UNLOAD] module-loopback"
         pactl unload-module module-loopback
         echo "[UNLOAD] module-remap-source"
         pactl unload-module module-remap-source
         echo "[UNLOAD] module-null-sink"
         pactl unload-module module-null-sink
     }

     init() {
         for exe in /usr/bin/pulseaudio /usr/bin/pactl; do
             if [ ! -x "$exe" ]; then
                 echo "[ERROR] required file $exe not found or not  executable"
                 exit 1
             fi
         done
         [ ! -x /usr/bin/pavucontrol ] && echo "[NOTICE] pavucontrol might be very useful."
     }

     # MAIN
     init;
     case $1 in
     activate|enable|start)
         do_activate;;
     deactivate|disable|stop)
         do_deactivate;;
     *)
         echo "Usage: $0 [enable|disable]";;
     esac;

しかし、これはスクリプトにあります:

@ Pantheon〜] $ pactlリストの短いソース

出力:

 0  alsa_output.pci-0000_00_1b.0.analog-stereo.monitor  module-alsa-           card.c   s16le 2ch 44100Hz   RUNNING
 1  alsa_input.pci-0000_00_1b.0.analog-stereo   module-alsa-card.c  s16le 2ch 44100Hz   RUNNING

しかし、私が必要としているのは次のようなものです。

 @Pantheon ~]$ pactl list sources|grep input

出力内容:

Name: alsa_input.pci-0000_00_1b.0.analog-stereo
    analog-input-front-mic: Front Microphone (priority: 8500, not   available)
    analog-input-rear-mic: Rear Microphone (priority: 8200, not available)
    analog-input-linein: En línea (priority: 8100, not available)
Puerto Activo: analog-input-front-mic

これはデバイスではなくポートです。レコードからの出力は

 $ arecord -l
 **** List of CAPTURE Hardware Devices ****
 card 0: Intel [HDA Intel], device 0: VT1708B 8-Ch Analog [VT1708B 8-Ch Analog]
  Subdevices: 0/1
  Subdevice #0: subdevice #0

そう; alsaまたはpulseaudioを介してこれらのポートにアクセスするにはどうすればよいですか?または、次のようなより単純なソリューションにする必要があります。

$ arecord 1 channel1.wav&arecord 2 channel2.wav
1
ape1

サウンドカードにはキャプチャデバイスが1つしかありません。つまり、一度に1つのポートからしか録音できません。

CM108 USBサウンドカードと内蔵サウンドカードを使用して、問題なく同時に録音しました。

1
cmnybo