import imageCommon = require("./image-common"); import dependencyObservable = require("ui/core/dependency-observable"); import proxy = require("ui/core/proxy"); import * as enumsModule from "ui/enums"; import style = require("ui/styling/style"); import view = require("ui/core/view"); global.moduleMerge(imageCommon, exports); var enums: typeof enumsModule; function ensureEnums() { if (!enums) { enums = require("ui/enums"); } } function onStretchPropertyChanged(data: dependencyObservable.PropertyChangeData) { var image = data.object; if (!image.android) { return; } ensureEnums(); switch (data.newValue) { case enums.Stretch.aspectFit: image.android.setScaleType(android.widget.ImageView.ScaleType.FIT_CENTER); break; case enums.Stretch.aspectFill: image.android.setScaleType(android.widget.ImageView.ScaleType.CENTER_CROP); break; case enums.Stretch.fill: image.android.setScaleType(android.widget.ImageView.ScaleType.FIT_XY); break; case enums.Stretch.none: default: image.android.setScaleType(android.widget.ImageView.ScaleType.MATRIX); break; } } function onImageSourcePropertyChanged(data: dependencyObservable.PropertyChangeData) { var image = data.object; if (!image.android) { return; } image._setNativeImage(data.newValue ? data.newValue.android : null); } // register the setNativeValue callback (imageCommon.Image.imageSourceProperty.metadata).onSetNativeValue = onImageSourcePropertyChanged; (imageCommon.Image.stretchProperty.metadata).onSetNativeValue = onStretchPropertyChanged; export class Image extends imageCommon.Image { private _android: org.nativescript.widgets.ImageView; get android(): org.nativescript.widgets.ImageView { return this._android; } public _createUI() { this._android = new org.nativescript.widgets.ImageView(this._context); } public _setNativeImage(nativeImage: any) { this.android.setImageBitmap(nativeImage); } } export class ImageStyler implements style.Styler { // tint color private static setTintColorProperty(view: view.View, newValue: any) { var imageView = view._nativeView; imageView.setColorFilter(newValue); } private static resetTintColorProperty(view: view.View, nativeValue: number) { var imageView = view._nativeView; imageView.clearColorFilter(); } public static registerHandlers() { style.registerHandler(style.tintColorProperty, new style.StylePropertyChangedHandler( ImageStyler.setTintColorProperty, ImageStyler.resetTintColorProperty), "Image"); } } ImageStyler.registerHandlers();