Важно помнить, что подобный вам код запускается только один раз при каждом рендере. По сути, это объявление для интерполяции
const backgroundColor = position.interpolate({
inputRange: [0, 100],
outputRange: ['red', 'blue'],
});
//
<View style={{ backgroundColor }} />
Если, скажем, ваш рендер вызывается один раз, это не мешает вашему представлению изменить цвет фона в будущем в ответ на изменение анимированного значения, даже если это рендер никогда больше не будет вызываться. Так поможет ли вам узнать ценность этой анимации всего один раз? Даже если бы вы могли получить его таким образом, вы не получите обновленное значение в следующий раз, когда оно изменится (если только ваш рендеринг не запущен по какой-то другой не связанной причине). Значение не является реактивным и почти всегда будет бесполезным для целей рендеринга.
Правильный способ сделать это - подключить слушателя к анимированному значению
componentDidMount() {
this.props.status.interpolate.addListener(({ value }) => {
console.log('new value: ', value)
this.lastKnownValue = value
})
}
. Это будет уведомлять вас каждый раз. значение меняется. Если вы все еще хотите получить доступ к этому значению при рендеринге, просто сохраните его где-нибудь (в свойстве класса компонента на основе класса или в ref-контейнере функционального компонента) и прочитайте его оттуда во время рендеринга