Схуднення сценарію (для кращої ефективності) Форум

кращої

Я прагну зменшити свій поточний сценарій (для кращої роботи!) Та кращої читабельності!
Сценарій керує модулем 'SimpleGain'.
Якщо хтось може дати кілька пропозицій щодо того, як я можу зробити це більш ефективним, я справді це вдячний!

На даний момент це сценарій:

Залежно від того, яка кнопка (Sampler) обрана (SMP0, SMP1), повзунок керує значенням/параметром даного модуля.
Працює як є . але ідентифікатор хотів би зробити його більш раціональним/ефективним.

Я все ще дуже багато @ -noob етапу з точки зору Hise/JS . так що я начебто у вакуумі моїх власних думок

Я думаю, що об’єкт, змінна, varIndex. Але я боюся, як це зробити.

Якщо у вас є хвилина, я люблю пропозицію!

Дуже дякую!

Вам не потрібні valGain або valPan, ви можете просто звернутися до цих атрибутів безпосередньо за допомогою SimpleGain_SMP0.Gain та SimpleGain_SMP0.Balance .

Тут ви повинні зробити те саме, щоб ви не використовували магічне число 0, ви повинні використовувати SimpleGain_SMP0.Gain та SimpleGain_SMP1.Gain. Те саме стосується і параметра pan.

Ви можете зменшити рядки коду, якщо помістити прості ефекти посилення в масив замість двох окремих змінних. Однак це не зробить його більш ефективним, він просто використовуватиме менше рядків коду.

@ ten7kur Ось як би я до цього підійшов:

Це може бути тонко зрозуміти для початківців, але це дозволяє додавати стільки модулів/пробовідбірників, скільки вам потрібно, майже без витрат на обслуговування.

І найпростіше рішення, якщо ваш код це дозволяє:

Зверніть увагу, що ви все ще можете використовувати контрольні зворотні виклики для регуляторів замість підключень редактора властивостей.

Не викликайте метод getComponent у контрольному зворотному виклику, а зберігайте його у змінній. Решта - косметика.

Вам не потрібні valGain або valPan, ви можете просто звернутися до цих атрибутів безпосередньо за допомогою SimpleGain_SMP0.Gain та SimpleGain_SMP0.Balance.

Це робиться: повзунок реагує неправильно.

@ ten7kur Ось як би я до цього підійшов:

Це може бути тонко зрозуміти для початківців, але це дозволяє додавати стільки модулів/пробовідбірників, скільки вам потрібно, майже без витрат на обслуговування.

І найпростіше рішення, якщо ваш код це дозволяє:

Зверніть увагу, що ви все ще можете використовувати контрольні зворотні виклики для регуляторів замість підключень редактора властивостей.

Мені подобається ваше рішення ! Потрібно трохи посидіти і переварити це. Але Sampler1 (на кнопці SMP1) не відображає правильних значень. Незважаючи на те, що код однаковий.

Не викликайте метод getComponent у контрольному зворотному виклику, а зберігайте його у змінній. Решта - косметика.

Намагався всіляко отримати значення раніше.
В порядку. Це змінна!
Спасибі!

@ ten7kur І набагато простіше, ніж моє перше рішення
Зрештою, я видалив непотрібні для циклів:

Але Sampler1 (на кнопці SMP1) не відображає правильних значень

Тут добре виглядає, коли я імпортую фрагмент.

тьфу!
Я розумію, що "b" - це масив "SmpSelectBtns", але я ніколи не бачив такого ControlCallback!
Мої травлення бореться в цей момент

@ ten7kur Це не контрольний зворотний виклик, це присвоєння функції, що викликається onSmpSelectBtnsControl, як функції зворотного виклику кожній кнопці b .

mhm я бачу. Це аргумент/цикл FOR після функції.
Ніколи не бачив такого.
Незважаючи на те, що я отримую логіку, код для мене все ще є додатковими крилами. Буде перетравлювати з надією

@ ten7kur Ви бачили моє відео HISE Scripting 101?

@ ten7kur Ви бачили моє відео HISE Scripting 101?

Я зробив це, хоча це було деякий час. Перегляне його ще раз.