avm2: Expose `width` to AS3 code.
This commit is contained in:
parent
3225cd40e2
commit
abca120628
|
@ -95,7 +95,7 @@ pub fn set_height<'gc>(
|
||||||
Ok(Value::Undefined)
|
Ok(Value::Undefined)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Implements `scaleX`'s getter.
|
/// Implements `scaleY`'s getter.
|
||||||
pub fn scale_y<'gc>(
|
pub fn scale_y<'gc>(
|
||||||
activation: &mut Activation<'_, 'gc, '_>,
|
activation: &mut Activation<'_, 'gc, '_>,
|
||||||
this: Option<Object<'gc>>,
|
this: Option<Object<'gc>>,
|
||||||
|
@ -110,7 +110,7 @@ pub fn scale_y<'gc>(
|
||||||
Ok(Value::Undefined)
|
Ok(Value::Undefined)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Implements `scaleX`'s setter.
|
/// Implements `scaleY`'s setter.
|
||||||
pub fn set_scale_y<'gc>(
|
pub fn set_scale_y<'gc>(
|
||||||
activation: &mut Activation<'_, 'gc, '_>,
|
activation: &mut Activation<'_, 'gc, '_>,
|
||||||
this: Option<Object<'gc>>,
|
this: Option<Object<'gc>>,
|
||||||
|
@ -128,6 +128,40 @@ pub fn set_scale_y<'gc>(
|
||||||
Ok(Value::Undefined)
|
Ok(Value::Undefined)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Implements `width`'s getter.
|
||||||
|
pub fn width<'gc>(
|
||||||
|
_activation: &mut Activation<'_, 'gc, '_>,
|
||||||
|
this: Option<Object<'gc>>,
|
||||||
|
_args: &[Value<'gc>],
|
||||||
|
) -> Result<Value<'gc>, Error> {
|
||||||
|
if let Some(dobj) = this.and_then(|this| this.as_display_object()) {
|
||||||
|
return Ok(dobj.width().into());
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(Value::Undefined)
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Implements `width`'s setter.
|
||||||
|
pub fn set_width<'gc>(
|
||||||
|
activation: &mut Activation<'_, 'gc, '_>,
|
||||||
|
this: Option<Object<'gc>>,
|
||||||
|
args: &[Value<'gc>],
|
||||||
|
) -> Result<Value<'gc>, Error> {
|
||||||
|
if let Some(dobj) = this.and_then(|this| this.as_display_object()) {
|
||||||
|
let new_width = args
|
||||||
|
.get(0)
|
||||||
|
.cloned()
|
||||||
|
.unwrap_or(Value::Undefined)
|
||||||
|
.coerce_to_number(activation)?;
|
||||||
|
|
||||||
|
if new_width >= 0.0 {
|
||||||
|
dobj.set_width(activation.context.gc_context, new_width);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(Value::Undefined)
|
||||||
|
}
|
||||||
|
|
||||||
/// Implements `scaleX`'s getter.
|
/// Implements `scaleX`'s getter.
|
||||||
pub fn scale_x<'gc>(
|
pub fn scale_x<'gc>(
|
||||||
activation: &mut Activation<'_, 'gc, '_>,
|
activation: &mut Activation<'_, 'gc, '_>,
|
||||||
|
@ -197,6 +231,14 @@ pub fn create_class<'gc>(mc: MutationContext<'gc, '_>) -> GcCell<'gc, Class<'gc>
|
||||||
QName::new(Namespace::package(""), "scaleY"),
|
QName::new(Namespace::package(""), "scaleY"),
|
||||||
Method::from_builtin(set_scale_y),
|
Method::from_builtin(set_scale_y),
|
||||||
));
|
));
|
||||||
|
write.define_instance_trait(Trait::from_getter(
|
||||||
|
QName::new(Namespace::package(""), "width"),
|
||||||
|
Method::from_builtin(width),
|
||||||
|
));
|
||||||
|
write.define_instance_trait(Trait::from_setter(
|
||||||
|
QName::new(Namespace::package(""), "width"),
|
||||||
|
Method::from_builtin(set_width),
|
||||||
|
));
|
||||||
write.define_instance_trait(Trait::from_getter(
|
write.define_instance_trait(Trait::from_getter(
|
||||||
QName::new(Namespace::package(""), "scaleX"),
|
QName::new(Namespace::package(""), "scaleX"),
|
||||||
Method::from_builtin(scale_x),
|
Method::from_builtin(scale_x),
|
||||||
|
|
Loading…
Reference in New Issue