ตั้งแต่วันที่ 27 มีนาคม 2025 เป็นต้นไป เราขอแนะนำให้ใช้ android-latest-release
แทน aosp-main
เพื่อสร้างและมีส่วนร่วมใน AOSP โปรดดูข้อมูลเพิ่มเติมที่หัวข้อการเปลี่ยนแปลงใน AOSP
จัดทุกอย่างให้เป็นระเบียบอยู่เสมอด้วยคอลเล็กชัน
บันทึกและจัดหมวดหมู่เนื้อหาตามค่ากำหนดของคุณ
ข้อมูลอ้างอิงเกี่ยวกับโครงสร้าง audio_hw_device
#include <
audio.h
>
|
struct
hw_device_t
|
common
|
|
uint32_t(*
|
get_supported_devices
)(const struct
audio_hw_device
*dev)
|
|
int(*
|
init_check
)(const struct
audio_hw_device
*dev)
|
|
int(*
|
set_voice_volume
)(struct
audio_hw_device
*dev, float volume)
|
|
int(*
|
set_master_volume
)(struct
audio_hw_device
*dev, float volume)
|
|
int(*
|
get_master_volume
)(struct
audio_hw_device
*dev, float *volume)
|
|
int(*
|
set_mode
)(struct
audio_hw_device
*dev, audio_mode_t mode)
|
|
int(*
|
set_mic_mute
)(struct
audio_hw_device
*dev, bool state)
|
|
int(*
|
get_mic_mute
)(const struct
audio_hw_device
*dev, bool *state)
|
|
int(*
|
set_parameters
)(struct
audio_hw_device
*dev, const char *kv_pairs)
|
|
char *(*
|
get_parameters
)(const struct
audio_hw_device
*dev, const char *keys)
|
|
size_t(*
|
get_input_buffer_size
)(const struct
audio_hw_device
*dev, const struct audio_config *config)
|
|
int(*
|
open_output_stream
)(struct
audio_hw_device
*dev, audio_io_handle_t handle, audio_devices_t devices, audio_output_flags_t flags, struct audio_config *config, struct
audio_stream_out
**stream_out, const char *address)
|
|
void(*
|
close_output_stream
)(struct
audio_hw_device
*dev, struct
audio_stream_out
*stream_out)
|
|
int(*
|
open_input_stream
)(struct
audio_hw_device
*dev, audio_io_handle_t handle, audio_devices_t devices, struct audio_config *config, struct
audio_stream_in
**stream_in, audio_input_flags_t flags, const char *address, audio_source_t source)
|
|
void(*
|
close_input_stream
)(struct
audio_hw_device
*dev, struct
audio_stream_in
*stream_in)
|
|
int(*
|
dump
)(const struct
audio_hw_device
*dev, int fd)
|
|
int(*
|
set_master_mute
)(struct
audio_hw_device
*dev, bool mute)
|
|
int(*
|
get_master_mute
)(struct
audio_hw_device
*dev, bool *mute)
|
|
int(*
|
create_audio_patch
)(struct
audio_hw_device
*dev, unsigned int num_sources, const struct audio_port_config *sources, unsigned int num_sinks, const struct audio_port_config *sinks, audio_patch_handle_t *handle)
|
|
int(*
|
release_audio_patch
)(struct
audio_hw_device
*dev, audio_patch_handle_t handle)
|
|
int(*
|
get_audio_port
)(struct
audio_hw_device
*dev, struct audio_port *port)
|
|
int(*
|
set_audio_port_config
)(struct
audio_hw_device
*dev, const struct audio_port_config *config)
|
|
คําจํากัดความที่บรรทัด
516
ของไฟล์
audio.h
.
int(* create_audio_patch)(struct
audio_hw_device
*dev, unsigned int num_sources, const struct audio_port_config *sources, unsigned int num_sinks, const struct audio_port_config *sinks, audio_patch_handle_t *handle)
|
การควบคุมการกำหนดเส้นทาง
คําจํากัดความที่บรรทัด
648
ของไฟล์
audio.h
.
วิธีนี้จะแสดงสถานะของฮาร์ดแวร์เสียง
คําจํากัดความที่บรรทัด
624
ของไฟล์
audio.h
.
int(* get_audio_port)(struct
audio_hw_device
*dev, struct audio_port *port)
|
size_t(* get_input_buffer_size)(const struct
audio_hw_device
*dev, const struct audio_config *config)
|
รับสถานะการปิดเสียงหลักปัจจุบันของ HAL หาก HAL รองรับการควบคุมการปิดเสียงหลัก AudioFlinger จะค้นหาค่านี้จาก HAL เสียงหลักเมื่อบริการเริ่มขึ้น และใช้ค่าดังกล่าวเพื่อตั้งค่าการปิดเสียงหลักเริ่มต้นใน HAL ทั้งหมด HAL ที่ไม่รองรับวิธีการนี้อาจตั้งค่าเป็น NULL
คําจํากัดความที่บรรทัด
639
ของไฟล์
audio.h
.
รับค่าระดับเสียงหลักปัจจุบันสำหรับ HAL หาก HAL รองรับการควบคุมระดับเสียงหลัก AudioFlinger จะค้นหาค่านี้จาก HAL เสียงหลักเมื่อบริการเริ่มขึ้น และใช้ค่าดังกล่าวเพื่อตั้งค่าระดับเสียงหลักเริ่มต้นใน HAL ทั้งหมด HAL ที่ไม่รองรับวิธีการนี้อาจตั้งค่าเป็น NULL
คําจํากัดความที่บรรทัด
561
ของไฟล์
audio.h
.
char*(* get_parameters)(const struct
audio_hw_device
*dev, const char *keys)
|
ที่ใช้โดย Flinger เสียงเพื่อแสดงรายการอุปกรณ์ที่รองรับในแต่ละการใช้งาน
audio_hw_device
ผลลัพธ์คือบิตมาสก์ของค่า audio_devices_t อย่างน้อย 1 ค่า
หมายเหตุ: การใช้งาน HAL เสียงที่ขึ้นต้นด้วย AUDIO_DEVICE_API_VERSION_2_0 จะไม่ใช้ฟังก์ชันนี้ อุปกรณ์ที่รองรับทั้งหมดควรแสดงอยู่ในไฟล์ audio_policy.conf และผู้จัดการนโยบายเสียงต้องเลือกโมดูลเสียงที่เหมาะสมตามข้อมูลในไฟล์นี้
คําจํากัดความที่บรรทัด
536
ของไฟล์
audio.h
.
ตรวจสอบว่าอินเทอร์เฟซฮาร์ดแวร์เสียงได้รับการเริ่มต้นแล้วหรือไม่ ผลลัพธ์คือ 0 หากสำเร็จ และ -ENODEV หากไม่สำเร็จ
คําจํากัดความที่บรรทัด
542
ของไฟล์
audio.h
.
int(* open_input_stream)(struct
audio_hw_device
*dev, audio_io_handle_t handle, audio_devices_t devices, struct audio_config *config, struct
audio_stream_in
**stream_in, audio_input_flags_t flags, const char *address, audio_source_t source)
|
เมธอดนี้จะสร้างและเปิดสตรีมอินพุตของฮาร์ดแวร์เสียง
คําจํากัดความที่บรรทัด
611
ของไฟล์
audio.h
.
int(* open_output_stream)(struct
audio_hw_device
*dev, audio_io_handle_t handle, audio_devices_t devices, audio_output_flags_t flags, struct audio_config *config, struct
audio_stream_out
**stream_out, const char *address)
|
วิธีนี้จะสร้างและเปิดสตรีมเอาต์พุตของฮาร์ดแวร์เสียง พารามิเตอร์ "address" จะกำหนดประเภทอุปกรณ์เสียง "devices" หากจำเป็น รูปแบบไฟล์จะขึ้นอยู่กับประเภทอุปกรณ์ ดังนี้
-
อุปกรณ์บลูทูธใช้ที่อยู่ MAC ของอุปกรณ์ในรูปแบบ "00:11:22:AA:BB:CC"
-
อุปกรณ์ USB ใช้การ์ด ALSA และหมายเลขอุปกรณ์ในรูปแบบ "card=X;device=Y"
-
อุปกรณ์อื่นๆ อาจใช้ตัวเลขหรือสตริงอื่นๆ
คําจํากัดความที่บรรทัด
599
ของไฟล์
audio.h
.
int(* release_audio_patch)(struct
audio_hw_device
*dev, audio_patch_handle_t handle)
|
int(* set_audio_port_config)(struct
audio_hw_device
*dev, const struct audio_port_config *config)
|
ตั้งค่าสถานะการปิดเสียงสำหรับกิจกรรมเสียงทั้งหมด หากระบบแสดงผลค่าอื่นที่ไม่ใช่ 0 มิกเซอร์ซอฟต์แวร์จะจำลองความสามารถนี้
คําจํากัดความที่บรรทัด
630
ของไฟล์
audio.h
.
ตั้งค่าระดับเสียงสำหรับกิจกรรมเสียงทั้งหมดที่ไม่ใช่การโทรด้วยเสียง ช่วงระหว่าง 0.0 ถึง 1.0 หากระบบแสดงผลค่าอื่นที่ไม่ใช่ 0 มิกเซอร์ซอฟต์แวร์จะจำลองความสามารถนี้
คําจํากัดความที่บรรทัด
552
ของไฟล์
audio.h
.
ระบบจะเรียกใช้ set_mode เมื่อโหมดเสียงมีการเปลี่ยนแปลง โหมด AUDIO_MODE_NORMAL มีไว้สําหรับการเล่นเสียงแบบมาตรฐาน, AUDIO_MODE_RINGTONE เมื่อเล่นเสียงเรียกเข้า และ AUDIO_MODE_IN_CALL เมื่อมีการโทรอยู่
คําจํากัดความที่บรรทัด
568
ของไฟล์
audio.h
.
ตั้งค่าระดับเสียงของสายสนทนาด้วยเสียง ช่วงอยู่ระหว่าง 0.0 ถึง 1.0
คําจํากัดความที่บรรทัด
545
ของไฟล์
audio.h
.
เอกสารประกอบสำหรับโครงสร้างนี้สร้างขึ้นจากไฟล์ต่อไปนี้
-
hardware/libhardware/include/hardware/
audio.h
ตัวอย่างเนื้อหาและโค้ดในหน้าเว็บนี้ขึ้นอยู่กับใบอนุญาตที่อธิบายไว้ในใบอนุญาตการใช้เนื้อหา Java และ OpenJDK เป็นเครื่องหมายการค้าหรือเครื่องหมายการค้าจดทะเบียนของ Oracle และ/หรือบริษัทในเครือ
อัปเดตล่าสุด 2025-03-26 UTC
[[["เข้าใจง่าย","easyToUnderstand","thumb-up"],["แก้ปัญหาของฉันได้","solvedMyProblem","thumb-up"],["อื่นๆ","otherUp","thumb-up"]],[["ไม่มีข้อมูลที่ฉันต้องการ","missingTheInformationINeed","thumb-down"],["ซับซ้อนเกินไป/มีหลายขั้นตอนมากเกินไป","tooComplicatedTooManySteps","thumb-down"],["ล้าสมัย","outOfDate","thumb-down"],["ปัญหาเกี่ยวกับการแปล","translationIssue","thumb-down"],["ตัวอย่าง/ปัญหาเกี่ยวกับโค้ด","samplesCodeIssue","thumb-down"],["อื่นๆ","otherDown","thumb-down"]],["อัปเดตล่าสุด 2025-03-26 UTC"],[],[]]