com.vaadin.polymer.iron.widget.IronImage Maven / Gradle / Ivy
/*
* This code was generated with Vaadin Web Component GWT API Generator,
* from iron-image project by The Polymer Authors
* that is licensed with http://polymer.github.io/LICENSE.txt license.
*/
package com.vaadin.polymer.iron.widget;
import com.vaadin.polymer.iron.element.*;
import com.vaadin.polymer.PolymerWidget;
import com.vaadin.polymer.elemental.*;
import com.google.gwt.core.client.JsArray;
import com.google.gwt.event.shared.HandlerRegistration;
import com.google.gwt.core.client.JavaScriptObject;
/**
* iron-image
is an element for displaying an image that provides useful sizing and
preloading options not found on the standard <img>
tag.
* The sizing
option allows the image to be either cropped (cover
) or
letterboxed (contain
) to fill a fixed user-size placed on the element.
* The preload
option prevents the browser from rendering the image until the
image is fully loaded. In the interim, either the element’s CSS background-color
can be be used as the placeholder, or the placeholder
property can be
set to a URL (preferably a data-URI, for instant rendering) for an
placeholder image.
* The fade
option (only valid when preload
is set) will cause the placeholder
image/color to be faded out once the image is rendered.
* Examples:
* Basically identical to <img src=”…”> tag:
* <iron-image src="http://lorempixel.com/400/400"></iron-image>
*
*
*
Will letterbox the image to fit:
* <iron-image style="width:400px; height:400px;" sizing="contain"
* src="http://lorempixel.com/600/400"></iron-image>
*
*
*
Will crop the image to fit:
* <iron-image style="width:400px; height:400px;" sizing="cover"
* src="http://lorempixel.com/600/400"></iron-image>
*
*
*
Will show light-gray background until the image loads:
* <iron-image style="width:400px; height:400px; background-color: lightgray;"
* sizing="cover" preload src="http://lorempixel.com/600/400"></iron-image>
*
*
*
Will show a base-64 encoded placeholder image until the image loads:
* <iron-image style="width:400px; height:400px;" placeholder="data:image/gif;base64,..."
* sizing="cover" preload src="http://lorempixel.com/600/400"></iron-image>
*
*
*
Will fade the light-gray background out once the image is loaded:
* <iron-image style="width:400px; height:400px; background-color: lightgray;"
* sizing="cover" preload fade src="http://lorempixel.com/600/400"></iron-image>
*
*
*
*
*/
public class IronImage extends PolymerWidget {
/**
* Default Constructor.
*/
public IronImage() {
this("");
}
/**
* Constructor used by UIBinder to create widgets with content.
*/
public IronImage(String html) {
super(IronImageElement.TAG, IronImageElement.SRC, html);
}
/**
* Gets a handle to the Polymer object's underlying DOM element.
*/
public IronImageElement getPolymerElement() {
try {
return (IronImageElement) getElement();
} catch (ClassCastException e) {
jsinteropError();
return null;
}
}
/**
*
*
* JavaScript Info:
* @property canLoad
* @type Boolean
*
*/
public boolean getCanLoad(){
return getPolymerElement().getCanLoad();
}
/**
*
*
* JavaScript Info:
* @property canLoad
* @type Boolean
*
*/
public void setCanLoad(boolean value) {
getPolymerElement().setCanLoad(value);
}
/**
* When preload
is true, setting fade
to true will cause the image to
fade into place.
*
* JavaScript Info:
* @property fade
* @type Boolean
*
*/
public boolean getFade(){
return getPolymerElement().getFade();
}
/**
* When preload
is true, setting fade
to true will cause the image to
fade into place.
*
* JavaScript Info:
* @property fade
* @type Boolean
*
*/
public void setFade(boolean value) {
getPolymerElement().setFade(value);
}
/**
* Can be used to set the height of image (e.g. via binding); size may also be
set via CSS.
*
* JavaScript Info:
* @property height
* @type Number
*
*/
public double getHeight(){
return getPolymerElement().getHeight();
}
/**
* Can be used to set the height of image (e.g. via binding); size may also be
set via CSS.
*
* JavaScript Info:
* @property height
* @type Number
*
*/
public void setHeight(double value) {
getPolymerElement().setHeight(value);
}
/**
* Can be used to set the height of image (e.g. via binding); size may also be
set via CSS.
*
* JavaScript Info:
* @attribute height
*
*/
public void setHeight(String value) {
getPolymerElement().setAttribute("height", value);
}
/**
* Read-only value that is true when the image is loaded.
*
* JavaScript Info:
* @property loaded
* @type Boolean
*
*/
public boolean getLoaded(){
return getPolymerElement().getLoaded();
}
/**
* Read-only value that is true when the image is loaded.
*
* JavaScript Info:
* @property loaded
* @type Boolean
*
*/
public void setLoaded(boolean value) {
getPolymerElement().setLoaded(value);
}
/**
* Read-only value that tracks the loading state of the image when the preload
option is used.
*
* JavaScript Info:
* @property loading
* @type Boolean
*
*/
public boolean getLoading(){
return getPolymerElement().getLoading();
}
/**
* Read-only value that tracks the loading state of the image when the preload
option is used.
*
* JavaScript Info:
* @property loading
* @type Boolean
*
*/
public void setLoading(boolean value) {
getPolymerElement().setLoading(value);
}
/**
* This image will be used as a background/placeholder until the src image has
loaded. Use of a data-URI for placeholder is encouraged for instant rendering.
*
* JavaScript Info:
* @property placeholder
* @type String
*
*/
public String getPlaceholder(){
return getPolymerElement().getPlaceholder();
}
/**
* This image will be used as a background/placeholder until the src image has
loaded. Use of a data-URI for placeholder is encouraged for instant rendering.
*
* JavaScript Info:
* @property placeholder
* @type String
*
*/
public void setPlaceholder(String value) {
getPolymerElement().setPlaceholder(value);
}
/**
* When a sizing option is uzed (cover
or contain
), this determines
how the image is aligned within the element bounds.
*
* JavaScript Info:
* @property position
* @type String
*
*/
public String getPosition(){
return getPolymerElement().getPosition();
}
/**
* When a sizing option is uzed (cover
or contain
), this determines
how the image is aligned within the element bounds.
*
* JavaScript Info:
* @property position
* @type String
*
*/
public void setPosition(String value) {
getPolymerElement().setPosition(value);
}
/**
* When true
, any change to the src
property will cause the placeholder
image to be shown until the
*
* JavaScript Info:
* @property preload
* @type Boolean
*
*/
public boolean getPreload(){
return getPolymerElement().getPreload();
}
/**
* When true
, any change to the src
property will cause the placeholder
image to be shown until the
*
* JavaScript Info:
* @property preload
* @type Boolean
*
*/
public void setPreload(boolean value) {
getPolymerElement().setPreload(value);
}
/**
* When true, the image is prevented from loading and any placeholder is
shown. This may be useful when a binding to the src property is known to
be invalid, to prevent 404 requests.
*
* JavaScript Info:
* @property preventLoad
* @type Boolean
*
*/
public boolean getPreventLoad(){
return getPolymerElement().getPreventLoad();
}
/**
* When true, the image is prevented from loading and any placeholder is
shown. This may be useful when a binding to the src property is known to
be invalid, to prevent 404 requests.
*
* JavaScript Info:
* @property preventLoad
* @type Boolean
*
*/
public void setPreventLoad(boolean value) {
getPolymerElement().setPreventLoad(value);
}
/**
*
*
* JavaScript Info:
* @property requiresPreload
* @type Boolean
*
*/
public boolean getRequiresPreload(){
return getPolymerElement().getRequiresPreload();
}
/**
*
*
* JavaScript Info:
* @property requiresPreload
* @type Boolean
*
*/
public void setRequiresPreload(boolean value) {
getPolymerElement().setRequiresPreload(value);
}
/**
* Sets a sizing option for the image. Valid values are contain
(full
aspect ratio of the image is contained within the element and
letterboxed) or cover
(image is cropped in order to fully cover the
bounds of the element), or null
(default: image takes natural size).
*
* JavaScript Info:
* @property sizing
* @type String
*
*/
public String getSizing(){
return getPolymerElement().getSizing();
}
/**
* Sets a sizing option for the image. Valid values are contain
(full
aspect ratio of the image is contained within the element and
letterboxed) or cover
(image is cropped in order to fully cover the
bounds of the element), or null
(default: image takes natural size).
*
* JavaScript Info:
* @property sizing
* @type String
*
*/
public void setSizing(String value) {
getPolymerElement().setSizing(value);
}
/**
* The URL of an image.
*
* JavaScript Info:
* @property src
* @type String
*
*/
public String getSrc(){
return getPolymerElement().getSrc();
}
/**
* The URL of an image.
*
* JavaScript Info:
* @property src
* @type String
*
*/
public void setSrc(String value) {
getPolymerElement().setSrc(value);
}
/**
* Can be used to set the width of image (e.g. via binding); size may also be
set via CSS.
*
* JavaScript Info:
* @property width
* @type Number
*
*/
public double getWidth(){
return getPolymerElement().getWidth();
}
/**
* Can be used to set the width of image (e.g. via binding); size may also be
set via CSS.
*
* JavaScript Info:
* @property width
* @type Number
*
*/
public void setWidth(double value) {
getPolymerElement().setWidth(value);
}
/**
* Can be used to set the width of image (e.g. via binding); size may also be
set via CSS.
*
* JavaScript Info:
* @attribute width
*
*/
public void setWidth(String value) {
getPolymerElement().setAttribute("width", value);
}
/**
*
*
* JavaScript Info:
* @property observers
* @type Array
*
*/
public JsArray getObservers(){
return getPolymerElement().getObservers();
}
/**
*
*
* JavaScript Info:
* @property observers
* @type Array
*
*/
public void setObservers(JsArray value) {
getPolymerElement().setObservers(value);
}
}