mirror of
https://github.com/NativeScript/NativeScript.git
synced 2025-08-15 02:54:11 +08:00

* chore: move tns-core-modules to nativescript-core * chore: preparing compat generate script * chore: add missing definitions * chore: no need for http-request to be private * chore: packages chore * test: generate tests for tns-core-modules * chore: add anroid module for consistency * chore: add .npmignore * chore: added privateModulesWhitelist * chore(webpack): added bundle-entry-points * chore: scripts * chore: tests changed to use @ns/core * test: add scoped-packages test project * test: fix types * test: update test project * chore: build scripts * chore: update build script * chore: npm scripts cleanup * chore: make the compat pgk work with old wp config * test: generate diff friendly tests * chore: create barrel exports * chore: move files after rebase * chore: typedoc config * chore: compat mode * chore: review of barrels * chore: remove tns-core-modules import after rebase * chore: dev workflow setup * chore: update developer-workflow * docs: experiment with API extractor * chore: api-extractor and barrel exports * chore: api-extractor configs * chore: generate d.ts rollup with api-extractor * refactor: move methods inside Frame * chore: fic tests to use Frame static methods * refactor: create Builder class * refactor: use Builder class in tests * refactor: include Style in ui barrel * chore: separate compat build script * chore: fix tslint errors * chore: update NATIVESCRIPT_CORE_ARGS * chore: fix compat pack * chore: fix ui-test-app build with linked modules * chore: Application, ApplicationSettings, Connectivity and Http * chore: export Trace, Profiling and Utils * refactor: Static create methods for ImageSource * chore: fix deprecated usages of ImageSource * chore: move Span and FormattedString to ui * chore: add events-args and ImageSource to index files * chore: check for CLI >= 6.2 when building for IOS * chore: update travis build * chore: copy Pod file to compat package * chore: update error msg ui-tests-app * refactor: Apply suggestions from code review Co-Authored-By: Martin Yankov <m.i.yankov@gmail.com> * chore: typings and refs * chore: add missing d.ts files for public API * chore: adress code review FB * chore: update api-report * chore: dev-workflow for other apps * chore: api update * chore: update api-report
286 lines
12 KiB
TypeScript
286 lines
12 KiB
TypeScript
/**
|
|
* Contains the ImageSource class, which encapsulates the common abstraction behind a platform specific object (typically a Bitmap) that is used as a source for images.
|
|
* @module "image-source"
|
|
*/ /** */
|
|
|
|
import { ImageAsset } from "../image-asset";
|
|
import { Font } from "../ui/styling/font";
|
|
import { Color } from "../color";
|
|
/**
|
|
* Encapsulates the common abstraction behind a platform specific object (typically a Bitmap) that is used as a source for images.
|
|
*/
|
|
export class ImageSource {
|
|
/**
|
|
* Gets the height of this instance. This is a read-only property.
|
|
*/
|
|
height: number;
|
|
|
|
/**
|
|
* Gets the width of this instance. This is a read-only property.
|
|
*/
|
|
width: number;
|
|
|
|
/**
|
|
* Gets or sets the rotation angle that should be applied to the image. (Used in android)
|
|
*/
|
|
rotationAngle: number;
|
|
|
|
/**
|
|
* The iOS-specific [UIImage](https://developer.apple.com/library/ios/documentation/UIKit/Reference/UIImage_Class/) instance. Will be undefined when running on Android.
|
|
*/
|
|
ios: any /* UIImage */;
|
|
|
|
/**
|
|
* The Android-specific [image](http://developer.android.com/reference/android/graphics/Bitmap.html) instance. Will be undefined when running on iOS.
|
|
*/
|
|
android: any /* android.graphics.Bitmap */;
|
|
|
|
/**
|
|
* Loads this instance from the specified asset asynchronously.
|
|
* @param asset The ImageAsset instance used to create ImageSource.
|
|
*/
|
|
static fromAsset(asset: ImageAsset): Promise<ImageSource>;
|
|
|
|
/**
|
|
* Downloads the image from the provided Url and creates a new ImageSource instance from it.
|
|
* @param url The link to the remote image object. This operation will download and decode the image.
|
|
*/
|
|
static fromUrl(url: string): Promise<ImageSource>;
|
|
|
|
/**
|
|
* Loads this instance from the specified resource name.
|
|
* @param name The name of the resource (without its extension).
|
|
*/
|
|
static fromResourceSync(name: string): ImageSource;
|
|
|
|
/**
|
|
* Loads this instance from the specified resource name asynchronously.
|
|
* @param name The name of the resource (without its extension).
|
|
*/
|
|
static fromResource(name: string): Promise<ImageSource>;
|
|
|
|
/**
|
|
* Loads this instance from the specified file.
|
|
* @param path The location of the file on the file system.
|
|
*/
|
|
static fromFileSync(path: string): ImageSource;
|
|
|
|
/**
|
|
* Loads this instance from the specified file asynchronously.
|
|
* @param path The location of the file on the file system.
|
|
*/
|
|
static fromFile(path: string): Promise<ImageSource>;
|
|
|
|
/**
|
|
* Creates a new ImageSource instance and loads it from the specified local file or resource (if specified with the "res://" prefix).
|
|
* @param path The location of the file on the file system.
|
|
*/
|
|
static fromFileOrResourceSync(path: string): ImageSource;
|
|
|
|
/**
|
|
* Loads this instance from the specified native image data.
|
|
* @param data The native data (byte array) to load the image from. This will be either Stream for Android or NSData for iOS.
|
|
*/
|
|
static fromDataSync(data: any): ImageSource;
|
|
|
|
/**
|
|
* Loads this instance from the specified native image data asynchronously.
|
|
* @param data The native data (byte array) to load the image from. This will be either Stream for Android or NSData for iOS.
|
|
*/
|
|
static fromData(data: any): Promise<ImageSource>;
|
|
|
|
/**
|
|
* Loads this instance from the specified base64 encoded string.
|
|
* @param source The Base64 string to load the image from.
|
|
*/
|
|
static fromBase64Sync(source: string): ImageSource;
|
|
|
|
/**
|
|
* Loads this instance from the specified base64 encoded string asynchronously.
|
|
* @param source The Base64 string to load the image from.
|
|
*/
|
|
static fromBase64(source: string): Promise<ImageSource>;
|
|
|
|
/**
|
|
* Creates a new ImageSource instance and loads it from the specified font icon code.
|
|
* @param source The hex font icon code string
|
|
* @param font The font for the corresponding font icon code
|
|
* @param color The color of the generated icon image
|
|
*/
|
|
static fromFontIconCodeSync(source: string, font: Font, color: Color): ImageSource;
|
|
|
|
/**
|
|
* Creates a new ImageSource instance and sets the provided native source object (typically a Bitmap).
|
|
* The native source object will update either the android or ios properties, depending on the target os.
|
|
* @param nativeSource The native image object. Will be either a Bitmap for Android or a UIImage for iOS.
|
|
*/
|
|
constructor(nativeSource?: any);
|
|
|
|
/**
|
|
* @deprecated Use ImageSource.fromAsset() instead.
|
|
* Loads this instance from the specified asset asynchronously.
|
|
* @param asset The ImageAsset instance used to create ImageSource.
|
|
*/
|
|
fromAsset(asset: ImageAsset): Promise<ImageSource>;
|
|
|
|
/**
|
|
* @deprecated Use ImageSource.fromResourceSync() instead.
|
|
* Loads this instance from the specified resource name.
|
|
* @param name The name of the resource (without its extension).
|
|
*/
|
|
loadFromResource(name: string): boolean;
|
|
|
|
/**
|
|
* @deprecated Use ImageSource.fromResource() instead.
|
|
* Loads this instance from the specified resource name asynchronously.
|
|
* @param name The name of the resource (without its extension).
|
|
*/
|
|
fromResource(name: string): Promise<boolean>;
|
|
|
|
/**
|
|
* @deprecated Use ImageSource.fromFileSync() instead.
|
|
* Loads this instance from the specified file.
|
|
* @param path The location of the file on the file system.
|
|
*/
|
|
loadFromFile(path: string): boolean;
|
|
|
|
/**
|
|
* @deprecated Use ImageSource.fromFile() instead.
|
|
* Loads this instance from the specified file asynchronously.
|
|
* @param path The location of the file on the file system.
|
|
*/
|
|
fromFile(path: string): Promise<boolean>;
|
|
|
|
/**
|
|
* @deprecated Use ImageSource.fromDataSync() instead.
|
|
* Loads this instance from the specified native image data.
|
|
* @param data The native data (byte array) to load the image from. This will be either Stream for Android or NSData for iOS.
|
|
*/
|
|
loadFromData(data: any): boolean;
|
|
|
|
/**
|
|
* @deprecated Use ImageSource.fromData() instead.
|
|
* Loads this instance from the specified native image data asynchronously.
|
|
* @param data The native data (byte array) to load the image from. This will be either Stream for Android or NSData for iOS.
|
|
*/
|
|
fromData(data: any): Promise<boolean>;
|
|
|
|
/**
|
|
* @deprecated Use ImageSource.fromBase64Sync() instead.
|
|
* Loads this instance from the specified base64 encoded string.
|
|
* @param source The Base64 string to load the image from.
|
|
*/
|
|
loadFromBase64(source: string): boolean;
|
|
|
|
/**
|
|
* @deprecated Use ImageSource.fromBase64() instead.
|
|
* Loads this instance from the specified base64 encoded string asynchronously.
|
|
* @param source The Base64 string to load the image from.
|
|
*/
|
|
fromBase64(source: string): Promise<boolean>;
|
|
|
|
/**
|
|
* @deprecated Use ImageSource.fromFontIconCode() instead.
|
|
* Loads this instance from the specified font icon code.
|
|
* @param source The hex font icon code string
|
|
* @param font The font for the corresponding font icon code
|
|
* @param color The color of the generated icon image
|
|
*/
|
|
loadFromFontIconCode(source: string, font: Font, color: Color): boolean;
|
|
|
|
/**
|
|
* Sets the provided native source object (typically a Bitmap or a UIImage).
|
|
* This will update either the android or ios properties, depending on the target os.
|
|
* @param nativeSource The native image object. Will be either a Bitmap for Android or a UIImage for iOS.
|
|
*/
|
|
setNativeSource(nativeSource: any): void;
|
|
|
|
/**
|
|
* Saves this instance to the specified file, using the provided image format and quality.
|
|
* @param path The path of the file on the file system to save to.
|
|
* @param format The format (encoding) of the image.
|
|
* @param quality Optional parameter, specifying the quality of the encoding. Defaults to the maximum available quality. Quality varies on a scale of 0 to 100.
|
|
*/
|
|
saveToFile(path: string, format: "png" | "jpeg" | "jpg", quality?: number): boolean;
|
|
|
|
/**
|
|
* Converts the image to base64 encoded string, using the provided image format and quality.
|
|
* @param format The format (encoding) of the image.
|
|
* @param quality Optional parameter, specifying the quality of the encoding. Defaults to the maximum available quality. Quality varies on a scale of 0 to 100.
|
|
*/
|
|
toBase64String(format: "png" | "jpeg" | "jpg", quality?: number): string;
|
|
}
|
|
|
|
/**
|
|
* @deprecated Use ImageSource.fromAsset() instead.
|
|
* Creates a new ImageSource instance and loads it from the specified image asset asynchronously.
|
|
* @param asset The image asset.
|
|
*/
|
|
export function fromAsset(asset: ImageAsset): Promise<ImageSource>;
|
|
|
|
/**
|
|
* @deprecated Use ImageSource.fromResourceSync() instead.
|
|
* Creates a new ImageSource instance and loads it from the specified resource name.
|
|
* @param name The name of the resource (without its extension).
|
|
*/
|
|
export function fromResource(name: string): ImageSource;
|
|
|
|
/**
|
|
* @deprecated Use ImageSource.fromFileSync() instead.
|
|
* Creates a new ImageSource instance and loads it from the specified file.
|
|
* @param path The location of the file on the file system.
|
|
*/
|
|
export function fromFile(path: string): ImageSource;
|
|
|
|
/**
|
|
* @deprecated Use ImageSource.fromDataSync() instead.
|
|
* Creates a new ImageSource instance and loads it from the specified native image data.
|
|
* @param data The native data (byte array) to load the image from. This will be either Stream for Android or NSData for iOS.
|
|
*/
|
|
export function fromData(data: any): ImageSource;
|
|
|
|
/**
|
|
* @deprecated Use ImageSource.fromBase64Sync() instead.
|
|
* Creates a new ImageSource instance and loads it from the specified base64 encoded string.
|
|
* @param source The base64 encoded string to load the image from.
|
|
*/
|
|
export function fromBase64(source: string): ImageSource;
|
|
|
|
/**
|
|
* @deprecated Use ImageSource constructor instead.
|
|
* Creates a new ImageSource instance and sets the provided native source object (typically a Bitmap).
|
|
* The native source object will update either the android or ios properties, depending on the target os.
|
|
* @param source The native image object. Will be either a Bitmap for Android or a UIImage for iOS.
|
|
*/
|
|
export function fromNativeSource(source: any): ImageSource;
|
|
|
|
/**
|
|
* @deprecated Use ImageSource.fromFontIconCodeSync() instead.
|
|
* Creates a new ImageSource instance and loads it from the specified font icon code.
|
|
* @param source The hex font icon code string
|
|
* @param font The font for the corresponding font icon code
|
|
* @param color The color of the generated icon image
|
|
*/
|
|
export function fromFontIconCode(source: string, font: Font, color: Color): ImageSource;
|
|
|
|
/**
|
|
* @deprecated Use ImageSource.fromUrl() instead.
|
|
* Downloads the image from the provided Url and creates a new ImageSource instance from it.
|
|
* @param url The link to the remote image object. This operation will download and decode the image.
|
|
*/
|
|
export function fromUrl(url: string): Promise<ImageSource>;
|
|
|
|
/**
|
|
* @deprecated Use ImageSource.fromFileOrResourceSync() instead.
|
|
* Creates a new ImageSource instance and loads it from the specified local file or resource (if specified with the "res://" prefix).
|
|
* @param path The location of the file on the file system.
|
|
*/
|
|
export function fromFileOrResource(path: string): ImageSource;
|
|
|
|
/**
|
|
* @deprecated Please use utils.isFileOrResourcePath instead.
|
|
* Returns true if the specified path points to a resource or local file.
|
|
* @param path The path.
|
|
*/
|
|
export function isFileOrResourcePath(path: string): boolean
|