教你一招,将Linux声音改为外放,听音乐更自在 (linux声音改为外放)

Linux作为一个开源的操作系统,一直以来备受好评。在Linux中使用音乐播放器是一种常见的需求。但是,当我们在Linux中使用音乐播放器时,会遇到一个很常见的问题:声音仅从耳机中播放,而不是外放。这可能会给用户带来很大的困扰,因为他们只能在没有其他人的情况下听音乐,除非他们购买一台外置音响。但是不用着急,Linux系统可以通过简单的步骤来解决这个问题。

步骤1: 安装Pulseaudio音频管理器(如果没有安装的话)

在Linux中,声音管理器是用于管理、控制和配置系统中所有声音设备的工具。因此,为了使音频外放,需要安装一个名为 Pulseaudio 的音频管理器。要安装此工具,请打开终端并运行以下命令。

“`

sudo apt-get install pulseaudio

“`

步骤2: 删除配置文件

如果您的Linux系统上运行了Pulseaudio,但仍然无法从扬声器中播放声音,则可以尝试删除Pulseaudio配置文件并重新启动系统。要删除配置文件,请打开终端并输入以下命令:

“`

rm -r ~/.config/pulse/

“`

此命令将删除所有存储在“~/.config/pulse/”中的Pulseaudio配置文件。

步骤3: 重启Pulseaudio

重启Pulseaudio也可能解决问题。在终端中运行以下命令:

“`

pulseaudio -k && pulseaudio –start

“`

这将关闭Pulseaudio并启动它。

步骤4: 确认输出设置

检查是否已将您的音频输出设置为扬声器。要检查,请按以下步骤操作。

1. 单击系统设置。

2. 单击声音选项卡。

3. 确认输出选项是否设置为扬声器。

步骤5: 打开Pavucontrol

如果上述步骤无效,则可以尝试打开Pavucontrol来设置扬声器。Pavucontrol是一种可用于更好地管理和控制声音在Linux中的软件。

要安装Pavucontrol,请输入以下命令:

“`

sudo apt-get install pavucontrol

“`

然后,要打开Pavucontrol,请在终端中输入以下命令:

“`

pavucontrol &

“`

在Pavucontrol中,单击“配置”选项卡,然后确认“内置音频”是否选中,并将“音频输出”设为扬声器。确保单击“将所有流路设为”应用程序之前的按钮,以使这些更改永久生效。

在本文中,我们介绍了如何将Linux系统中的声音设置为外放来完成音乐播放。尽管在Linux中设置声音可能需要一点调整,但是Linux并不是非常难使用。只要查看系统设置和Pavucontrol,使用者就可以很快地更改设置。希望这篇文章可以帮助那些在Linux中使用音乐播放器时无法将声音设置为外放的人。

相关问题拓展阅读:

为啥Linux系统插上耳机有声音,拔掉耳机就没有声音,而XP系统就有声音!

声卡支持的问题。这个只能靠升级系统解决。

你这个问题应该是驱动没有很好的解决声卡的 codec ,导致没有正确识别声卡的输出端口方式。导致李链只能使用声卡的耳机输出端口而不是机器的喇叭输出端口。

Linux 的声哪册孙卡驱动统一由 alsa 提供。alsa 已经被内置进了内核。

如果楼主的系统不是很新,那么升级系统或许可以解决。如果不行,那就只能自己升级内核了。如果还不行,那就只能去升级使用外挂最新版的 alsa 了。

另外,有的驱动可以通过设置 codec 型号给驱动来提供支持或者更改默认的输姿旅出端口。

不过这都需要足够的技术。

根据你的linux系统,在设置中找声音设置,然后选不同的模式试试。

系统设置问题

请教Linux下ALSA声道切换

解各参数含义及些基本概念

本度(sample):本记录音频数据基本单位见8位16位

通道数(channel):该参数1表示单声道2则立体声

桢(frame):桢记录声音单元其度本度与通道数乘积

采率(rate):每秒钟采数该数针桢言

周期(period):音频设备处理所需要桢数于音频设备数据访问及音频数据存储都单位

交错模式(interleaved):种音频数据记录式交错模式数据连续桢形式存放即首先记录完桢1左声道本右声道本(假设立体声格式)再始桢2记录非交错模式首先记录周期内所桢左声道本再记录右声道本数据连续通道式存储数情况我需要使用交错模式

period(周期):硬件断间间隔间表示输入延

声卡接口指针指示声卡硬件缓存区前读写位置要接口运行指针循环指向缓存区某位置

frame size = sizeof(one sample) * nChannels

alsa配置缓存(buffer)周期(size)runtime帧(frames)形式存储

period_bytes = frames_to_bytes(runtime, runtime->period_size);

bytes_to_frames()

The period and buffer sizes are not dependent on the sample format because they are measured in frames; you do not need to change them.

ALSA声音编程介绍

ALSA表示高级Linux声音体系结构(Advanced Linux Sound Architecture)由系薯衫列内核驱应用程序编译接口(API)及支持Linux声音实用程序组篇文章我简单介绍ALSA项目基本框架及软件组主要集介绍PCM接口编程包括您自实践程序示例

您使用ALSA原能新并唯用声音API您想完低级声音操作便能够化控制声音并化提高性能或者您使用其声音API没特性ALSA选择您已经写音频程序能想要ALSA声卡驱添加本支持您音频兴趣想播放音频文件高级API更选择比SDL,OpenAL及些桌面环境提供工具集另外您能ALSA支持Linux环境使用ALSA

ALSA历史

ALSA项目发起起Linux声卡驱(OSS/Free drivers)没积极维护并且落于新声卡技术Jaroslav Kysela早先写声卡驱并由始ALSA项目随便更发者加入发队伍更声卡支持API结构重组

Linux内核2.5发程ALSA合并官源码树发布内核2.6ALSA已经内建稳定内核版本并广泛使用

数字音频基础

声音由变化气压组麦克风转换器转换电形式模/数(ADC)转换器模拟电压转换离散本值声音固定间间隔采采速率称采率本输数/模(DAC)转换器比扩音器转换原模拟信号

本位表示本影响声音转换数字信号精确程度素另主要素采率奈奎斯特(Nyquist)理论要离散系统奈奎斯特频率高于采信号高频率或带宽避免混叠现象

ALSA基础

ALSA由许声卡声卡驱程序组同提供称libasoundAPI库应用程序发者应该使用libasound内核ALSA接口libasound提供数如腔橡消高级并且编程便编程接口并且提供设备逻辑命名功能发者甚至需要知道类似设备文件低层接口相反OSS/Free驱内核系统调用级编程要求发者提供设备文件名并且利用ioctrl实现相应功能向兼容ALSA提供内核模块模拟OSS前许OSS基础发应用程序需要任何改ALSA运行另外libaoss库模拟OSS需要内核模块

ALSA包含插件功能使用插件扩展新声卡驱包括完全用软件实现虚拟声卡ALSA提供系列基于命令行工具集比混音器(mixer)音频文件播放器(aplay)及控制特定声卡特定属性工具

ALSA体系结构

ALSA API解几主要接口:

1 控制接口:提供管理声卡注册请求用设备通用功能

2 PCM接口:管理数字音频放(playback)录音(capture)接口本文续总结重点放接口发数字音频程序用接口

3 Raw MIDI接口:支持MIDI(Musical Instrument Digital Interface),标准电乐器些API提供声卡MIDI总线访问原始接口基于MIDI事件工作由程序员负责管理协议及间处理

4 定器(Timer)接口:同步音频事件提供声卡间处理硬件访问

5 序器(Sequencer)接口

6 混音器(Mixer)接口

设备命名

API库使用逻辑设备名设备文件设备名字真实硬件名字插件名字硬件名字使用hw:i,j格式其i卡号j块声卡设备号第声音设备hw:0,0.别名默认引用第块声音设备并且本文示例真用插件使用另外唯名字比plughw:,表示插件插件提供硬件设备访问提供像采率转换软件特性硬件本身并支持特性

声音缓存数据传输

每声卡都硬件缓存区保存记录本缓存区足够满声卡产断内核声卡驱使用直接内存(DMA)访问通道本传送内存应用程序缓存区类似于放任何应用程序使用DMA自缓存区数据传送声卡硬件缓存区

硬件缓存区环缓存说数据达缓存区末尾重新缓存区起始位置ALSA维护指针指向硬件缓存及应用程序缓存区数据操作前位置内核外部看我应用程序缓存区兴趣所本文讨论应用程序缓存区

应用程序缓存区通ALSA库函数调用控制缓存区传输操作能导致接受延迟我称延(latency)解决问题ALSA缓存区拆系列周期(period)(OSS/Free叫片断fragments).ALSAperiod单元传送数据

周期(period)存储些帧(frames)每帧包含间点所抓取本于立体声设备帧包含两信道本图1展示解程:缓存区解周期帧本图包含些假定数值图左右信道信息交替存储帧内称交错(interleaved)模式非交错模式信道所本数据存储另外信道数据

Over and Under Run

声卡数据总连续硬件缓存区应用程序缓存区间传输例外录音例应用程序读取数据够快循环缓存区新数据覆盖种数据丢失称overrun.放例应用程序写入数据缓存区速度够快缓存区”饿死”错误称”underrun”ALSA文档两种情形统称”XRUN”适设计应用程序化XRUN并且恢复

典型声音程序

使用PCM程序通类似面伪代码:

打放或录音接口

设置硬件参数(访问模式数据格式信道数采率等等)

while 数据要处理:

读PCM数据(录音)

或 写PCM数据(放)

关闭接口

我文看些工作代码我建议您Linux系统测试运行些代码查看输并尝试修改推荐代码本文相关所实例清单FTP获取:ftp.ssc.com/pub/lj/listings/issue126/6735.tgz

Listing 1. Display Some PCM Types and Formats

#include asoundlib.h>

int main() {

int val;

printf(“ALSA library version: %s/n”,

SND_LIB_VERSION_STR);

printf(“/nPCM stream types:/n”);

for (val = 0; val

int main() {

int rc;

snd_pcm_t *handle;

snd_pcm_hw_params_t *params;

unsigned int val, val2;

int dir;

snd_pcm_uframes_t frames;

/* Open PCM device for playback. */

rc = snd_pcm_open(&handle, “default”,

SND_PCM_STREAM_PLAYBACK, 0);

if (rc

fprintf(stderr,

“unable to open pcm device: %s/n”,

snd_strerror(rc));

exit(1);

}

/* Allocate a hardware parameters object. */

snd_pcm_hw_params_alloca(?ms);

/* Fill it in with default values. */

snd_pcm_hw_params_any(handle, params);

/* Set the desired hardware parameters. */

/* Interleaved mode */

snd_pcm_hw_params_set_access(handle, params,

SND_PCM_ACCESS_RW_INTERLEAVED);

/* Signed 16-bit little-endian format */

snd_pcm_hw_params_set_format(handle, params,

SND_PCM_FORMAT_S16_LE);

/* Two channels (stereo) */

snd_pcm_hw_params_set_channels(handle, params, 2);

/*bits/second sampling rate (CD quality) */

val = 44100;

snd_pcm_hw_params_set_rate_near(handle,

params, &val, &dir);

/* Write the parameters to the driver */

rc = snd_pcm_hw_params(handle, params);

if (rc

fprintf(stderr,

“unable to set hw parameters: %s/n”,

snd_strerror(rc));

exit(1);

}

/* Display information about the PCM interface */

printf(“PCM handle name = ‘%s’/n”,

snd_pcm_name(handle));

printf(“PCM state = %s/n”,

snd_pcm_state_name(snd_pcm_state(handle)));

snd_pcm_hw_params_get_access(params,

(snd_pcm_access_t *) &val);

printf(“access type = %s/n”,

snd_pcm_access_name((snd_pcm_access_t)val));

snd_pcm_hw_params_get_format(params, &val);

printf(“format = ‘%s’ (%s)/n”,

snd_pcm_format_name((snd_pcm_format_t)val),

snd_pcm_format_description(

(snd_pcm_format_t)val));

snd_pcm_hw_params_get_subformat(params,

(snd_pcm_subformat_t *)&val);

printf(“subformat = ‘%s’ (%s)/n”,

snd_pcm_subformat_name((snd_pcm_subformat_t)val),

snd_pcm_subformat_description(

(snd_pcm_subformat_t)val));

snd_pcm_hw_params_get_channels(params, &val);

printf(“channels = %d/n”, val);

snd_pcm_hw_params_get_rate(params, &val, &dir);

printf(“rate = %d bps/n”, val);

snd_pcm_hw_params_get_period_time(params,

&val, &dir);

printf(“period time = %d us/n”, val);

snd_pcm_hw_params_get_period_size(params,

&frames, &dir);

printf(“period size = %d frames/n”, (int)frames);

snd_pcm_hw_params_get_buffer_time(params,

&val, &dir);

printf(“buffer time = %d us/n”, val);

snd_pcm_hw_params_get_buffer_size(params,

(snd_pcm_uframes_t *) &val);

printf(“buffer size = %d frames/n”, val);

snd_pcm_hw_params_get_periods(params, &val, &dir);

printf(“periods per buffer = %d frames/n”, val);

snd_pcm_hw_params_get_rate_numden(params,

&val, &val2);

printf(“exact rate = %d/%d bps/n”, val, val2);

val = snd_pcm_hw_params_get_its(params);

printf(“significant bits = %d/n”, val);

snd_pcm_hw_params_get_tick_time(params,

&val, &dir);

printf(“tick time = %d us/n”, val);

val = snd_pcm_hw_params_is_batch(params);

printf(“is batch = %d/n”, val);

val = snd_pcm_hw_params_is_block_transfer(params);

printf(“is block transfer = %d/n”, val);

val = snd_pcm_hw_params_is_double(params);

printf(“is double = %d/n”, val);

val = snd_pcm_hw_params_is_half_duplex(params);

printf(“is half duplex = %d/n”, val);

val = snd_pcm_hw_params_is_joint_duplex(params);

printf(“is joint duplex = %d/n”, val);

val = snd_pcm_hw_params_can_overrange(params);

printf(“can overrange = %d/n”, val);

val = snd_pcm_hw_params_can_mmap_sample_resolution(params);

printf(“can mmap = %d/n”, val);

val = snd_pcm_hw_params_can_pause(params);

printf(“can pause = %d/n”, val);

val = snd_pcm_hw_params_can_resume(params);

printf(“can resume = %d/n”, val);

val = snd_pcm_hw_params_can_sync_start(params);

printf(“can sync start = %d/n”, val);

snd_pcm_close(handle);

return 0;

}

linux声音改为外放的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux声音改为外放,教你一招,将Linux声音改为外放,听音乐更自在,为啥Linux系统插上耳机有声音,拔掉耳机就没有声音,而XP系统就有声音!,请教Linux下ALSA声道切换的信息别忘了在本站进行查找喔。


数据运维技术 » 教你一招,将Linux声音改为外放,听音乐更自在 (linux声音改为外放)