:right-sidebar: True SpringParams =================================================================== .. currentmodule:: gi.repository.Adw .. class:: SpringParams(**kwargs) :no-contents-entry: Physical parameters of a spring for :obj:`~gi.repository.Adw.SpringAnimation`\. Any spring can be described by three parameters: mass, stiffness and damping. An undamped spring will produce an oscillatory motion which will go on forever. The frequency and amplitude of the oscillations will be determined by the stiffness (how "strong" the spring is) and its mass (how much "inertia" it has). If damping is larger than 0, the amplitude of that oscillating motion will exponientally decrease over time. If that damping is strong enough that the spring can't complete a full oscillation, it's called an overdamped spring. If we the spring can oscillate, it's called an underdamped spring. The value between these two behaviors is called critical damping; a critically damped spring will comes to rest in the minimum possible time without producing oscillations. The damping can be replaced by damping ratio, which produces the following springs: - 0: an undamped spring. - Between 0 and 1: an underdamped spring. - 1: a critically damped spring. - Larger than 1: an overdamped spring. As such Constructors ------------ .. rst-class:: interim-class .. class:: SpringParams :no-index: .. classmethod:: new(damping_ratio: float, mass: float, stiffness: float) -> ~gi.repository.Adw.SpringParams Creates a new ``AdwSpringParams`` from ``mass``\, ``stiffness`` and ``damping_ratio``\. The damping value is calculated from ``damping_ratio`` and the other two parameters. - If ``damping_ratio`` is 0, the spring will not be damped and will oscillate endlessly. - If ``damping_ratio`` is between 0 and 1, the spring is underdamped and will always overshoot. - If ``damping_ratio`` is 1, the spring is critically damped and will reach its resting position the quickest way possible. - If ``damping_ratio`` is larger than 1, the spring is overdamped and will reach its resting position faster than it can complete an oscillation. :obj:`~gi.repository.SpringParams.new_full` allows to pass a raw damping value instead. :param damping_ratio: the damping ratio of the spring :param mass: the mass of the spring :param stiffness: the stiffness of the spring .. classmethod:: new_full(damping: float, mass: float, stiffness: float) -> ~gi.repository.Adw.SpringParams Creates a new ``AdwSpringParams`` from ``mass``\, ``stiffness`` and ``damping``\. See :obj:`~gi.repository.SpringParams.new` for a simplified constructor using damping ratio instead of ``damping``\. :param damping: the damping of the spring :param mass: the mass of the spring :param stiffness: the stiffness of the spring Methods ------- .. rst-class:: interim-class .. class:: SpringParams :no-index: .. method:: get_damping() -> float Gets the damping of ``self``\. .. method:: get_damping_ratio() -> float Gets the damping ratio of ``self``\. .. method:: get_mass() -> float Gets the mass of ``self``\. .. method:: get_stiffness() -> float Gets the stiffness of ``self``\.