Performans yapmak için ses uygulamasında VolumeShaper
kullanabilirsiniz
Kararma, kararma, çapraz geçiş, alçalma ve diğer kısa otomatik ses düzeyi
oluşturabilirsiniz. VolumeShaper
sınıfı, Android 8.0 (API düzeyi 26) sürümünde kullanılabilir.
oluşturabilirsiniz.
Şu örneğin bir örneğinde createVolumeShaper()
işlevini çağırarak bir VolumeShaper
oluşturursunuz:
AudioTrack
veya MediaPlayer
. İlgili içeriği oluşturmak için kullanılan
VolumeShaper
yalnızca AudioTrack veya MediaPlayer tarafından üretilen seste çalışır
harekete geçti.
VolumeShaper.Yapılandırması
VolumeShaper
davranışı şu şekilde tanımlanır:
VolumeShaper.Configuration
. Yapılandırma,
*ses eğrisi, interpolator türü ve süre.*
Hacim eğrisi
Hacim eğrisi, zaman içinde genlik değişimini temsil eder. Bir çiftle tanımlanır
bir dizi kontrol noktasını tanımlayan x[] ve y[] kayan dizileri. Her biri (x, y)
çifti sırasıyla zamanı ve hacmi temsil eder. Dizilerin uzunluğu eşit olmalıdır
ve en az 2, en fazla 16 değer içermelidir. (Maksimum eğri uzunluğu
getMaximumCurvePoints()
içinde tanımlanır.)
Zaman koordinatları, [0,0, 1,0] aralığı üzerinden verilir. İlk kez punto 0,0, son değer 1,0 ve saatler tekdüze olmalıdır. artıyor.
Hacim koordinatları, aralık üzerindeki doğrusal ölçekte belirtilir [0,0, 1,0] olarak değiştirildi.
İnterpolatör türü
Hacim eğrisi her zaman belirtilen kontrol noktalarından geçer. Değerler
kontrol noktaları arasındaki kontrol noktalarına göre bir eğriyle türetilir
belirleyicidir. Kullanılabilir
VolumeShaper
interpolator türü:
- VolumeShaper.Yapılandırma.INTERPOLATOR_TYPE_STEP
- VolumeShaper.Yapılandırma.INTERPOLATOR_TYPE_LINEAR
- VolumeShaper.Yapılandırma.INTERPOLATOR_TYPE_CUBIC
- VolumeShaper.Yapılandırma.INTERPOLATOR_TYPE_CUBIC_MONOTONIC
Süre
[0,0, 1,0] aralığında belirtilen zaman koordinatları milisaniye cinsinden belirttiğiniz süre. Bu, toplamda şekillendirici çalışırken ve eğriyi çembere uygularken hacim eğrisinin zamanı ses çıkışını kullanın.
VolumeShaper Kullanma
Yapılandırma oluşturma
Bir VolumeShaper
derlemeden önce VolumeShaper.Configuration
örneği oluşturmanız gerekir. Bunu bir
VolumeShaper.Configuration.Builder()
:
val config: VolumeShaper.Configuration = VolumeShaper.Configuration.Builder()
.setDuration(3000)
.setCurve(floatArrayOf(0f, 1f), floatArrayOf(0f, 1f))
.setInterpolatorType(VolumeShaper.Configuration.INTERPOLATOR_TYPE_LINEAR)
.build()
VolumeShaper.Configuration config =
new VolumeShaper.Configuration.Builder()
.setDuration(3000)
.setCurve(new float[] {0.f, 1.f}, new float[] {0.f, 1.f})
.setInterpolatorType(VolumeShaper.Configuration.INTERPOLATOR_TYPE_LINEAR)
.build();
With no arguments the VolumeShaper.Configuration.Builder
constructor returns a
builder that creates a configuration with default settings:
INTERPOLATOR_TYPE_CUBIC, a one second duration, and no curve. You must add a
curve to the builder before calling build()
.
The framework provides constants for configurations with pre-built curves, each with one second duration:
VolumeShaper.Configuration.LINEAR_RAMP
VolumeShaper.Configuration.CUBIC_RAMP
VolumeShaper.Configuration.SINE_RAMP
VolumeShaper.Configuration.SCURVE_RAMP
Creating a VolumeShaper
To create a VolumeShaper
, call createVolumeShaper()
on an instance of the
appropriate class, passing in a VolumeShaper.Configuration
:
volumeShaper = myMediaPlayer.createVolumeShaper(config)
volumeShaper = myAudioTrack.createVolumeShaper(config)
volumeShaper = myMediaPlayer.createVolumeShaper(config);
volumeShaper = myAudioTrack.createVolumeShaper(config);
A single track or media player can have many shapers attached to it, and you can
control each shaper separately. The outputs of all the shapers on a track or
player are multiplied together. A VolumeShaper
cannot be shared between
AudioTracks
or MediaPlayers
, but you can use the same configuration in calls
to createVolumeShaper
to build identical shapers on multiple AudioTracks
or
MediaPlayers
.
When you create the shaper, its first control point (at t = 0) is applied to the
audio stream. If the initial volume is not 1.0 and your app is playing material
at create time, your audio might have an abrupt change in volume. Best practice
is to start playing audio from silence and use a VolumeShaper
to implement a
fade-in when playback starts. Create a VolumeShaper
that starts at 0 volume
and fades up. For example:
setCurve(new float[] {0.f, 1.f}, new float[] {0.f, 1.f})
Oynatmayı ve şekil oluşturucuyu aynı anda başlatın. Bu, oynatmanın ses sessizden başlar ve ses en üst düzeye çıkarılır. Bunun açıklaması ele alacağız.
VolumeShaper Çalıştırma
İlk kontrol noktasının ses düzeyi, ses yoluna uygulansa da
Şekillendirici oluşturulduğunda, şekillendirici eğri boyunca ilerlemez
siz VolumeShaper.Operation.PLAY
ile apply()
yöntemini çağırıncaya kadar. Şu tarihten sonra:
şekillendirici oluşturuluyorsa, apply()
ilk çağrısında PLAY
belirtilmelidir
işlemini başlatacağım. Bu, eğriyi ilkinden başlayıp
son kontrol noktaları:
Shar.apply(VolumeShaper.Operation.PLAY)
Shar.apply(VolumeShaper.Operation.PLAY);
Şekillendirici çalışırken, alternatif apply()
çağrılarını belirten bir ileti oluşturabilirsiniz.
REVERSE ve PLAY işlemleri. Bu,
kontrol noktaları anlamına gelir.
Şekillendirici, ses düzeyini sürekli olarak ayarlar ve tüm kontrol noktalarından geçer. kullanım süresi dolana kadar bekleyin. Bu, şekil şekli sonuncuya ulaştığında gerçekleşir (PLAY için işlemi) veya ilk (GERİ ALMA işlemi için) denetim noktasını seçin.
Şekillendiricinin süresi dolduğunda, ses düzeyi son ayarda kalır. Bu değer,
kontrol noktası
olabilir. VolumeShaper.getVolume()
numaralı telefonu arayabilirsiniz:
mevcut ses düzeyini istediğiniz zaman değiştirebilirsiniz.
Şekillendiricinin süresi dolduktan sonra, eğriyi çalıştırmak için başka bir apply()
çağrısı yayınlayabilirsiniz
yönde görüyorum. Örneğin, şekillendiricinin süresi çalışırken
PLAY
, sonraki apply()
REVERSE
olmalıdır. PLAY
şu süre geçtikten sonra PLAY
aranacak:
süresi dolduktan sonra veya REVERSE
süresi dolduktan sonra REVERSE
ürününün herhangi bir etkisi olmaz.
PLAY
ve REVERSE
işlemlerini değiştirmeniz gerekir. Burada hiçbir şekilde
öncekinden son kontrol noktalarına kadar eğimli olup daha sonra
ilk denetim noktasıdır. Sonraki adımda açıklanan replace()
yöntemini kullanabilirsiniz
bölümünde, eğriyi kendisinin bir kopyasıyla değiştirin. Bu, şekillendiriciyi sıfırlar.
PLAY
işleminin yeniden başlatılması gerekiyor.
Eğriyi değiştirme
VolumeShaper
eğrisini değiştirmek için replace()
yöntemini kullanın. Bu yöntem
bir yapılandırma, işlem ve birleştirme parametresidir. Örneğin,
replace()
yöntemini istediğiniz zaman değiştirebilirsiniz: Şekillendirici çalışırken veya süresi dolduktan sonra:
val newConfig = VolumeShaper.Configuration.Builder()
.setDuration(1000)
.setCurve(floatArrayOf(0f; 0,5f); floatArrayOf(0f; 1f))
.setInterpolatorType(VolumeShaper.Configuration.INTERPOLATOR_TYPE_LINEAR)
.build()
val Join = doğru
Shar.replace(newConfig, VolumeShaper.Operation.PLAY, birleştirme)
VolumeShaper.Configuration newConfig =
yeni VolumeShaper.Configuration.Builder()
.setDuration(1000)
.setCurve(yeni kayan noktalı[] {0.f, 0.5f}, yeni kayan nokta[] {0.f, 1.f})
.setInterpolatorType(VolumeShaper.Configuration.INTERPOLATOR_TYPE_LINEAR)
.build();
boolejoin = true;
Shar.replace(newConfig, VolumeShaper.Operation.PLAY, join);
Şekillendirici çalışırken replace()
işlevini çağırdığınızda,
ve şu anki değerinde kalır. Ardından şekillendirici, yeni yapıya başlamaya çalışır.
eğrisini oluşturabilirsiniz. Yani, işlem bağımsız değişkeni
Şekillendiricinin çağrıdan sonra çalışıp çalışmayacağını kontrol eder. Şunu belirtmek için PLAY
değerini belirtin:
yeni eğriyi hemen başlatın, şekillendiriciyi duraklatılmış durumda bırakmak için REVERSE
değerini belirtin
yeni eğrideki ilk kontrol noktasının hacmi. Şekillendiriciyi oluşturmaya başlayabilirsiniz
daha sonra apply(VolumeShaper.Operation.PLAY)
ile devam edin.
join = false
ile replace()
çağrısı yaptığınızda, şekillendiricinin eğrisinin başlangıç noktası:
ilk kontrol noktası tarafından belirtilen seviye. Bu durum,
verilerin kesilmesine
ses düzeyinde kontrol edin. join = true
üzerinden replace()
numaralı telefonu arayarak bu durumdan kaçınabilirsiniz.
Bu, yeni eğrinin ilk kontrol noktasını
kontrol noktalarının hacmini
olarak ölçeklendirir.
Yeni eğrinin göreceli şeklini korumak için son kontrol noktası (son kontrol noktası
değiştirilebilir. Ölçeklendirme işlemi,
yeni eğrisi üzerinde çalışıyorum.
VolumeShaper'ı Kaldırma
AudioTrack
veya şu durumlarda sistem kapatılır ve atık VolumeShaper
toplanır:
MediaPlayer
yayınlandı veya artık kullanılmıyor. close()
yöntemini çağırabilirsiniz
hemen imha etmeye çalışır. Sistem, şekil oluşturucuyu
ses ardışık düzenine yaklaşık 20 ms. VolumeShaper
öğesini kapatırken dikkatli olun
yardımcı olur. Aradığınızda şekillendiricinin sesi 1,0'dan azsa
close()
, şekillendiricinin ses ölçeği 1,0 olarak değişir. Bu durum aniden
yardımcı olabilir.