The Titanium binding of Android RemoteViews.
RemoteViews
is an API for referencing and updating a remote view hierarchy that
lives in another process, for example, in a Notification.
To create a remote view hierarchy, you must define an Android XML layout for the views
you want to display, and place the XML file in the platform/android/res/layout
inside your
project folder. See the examples for a sample XML layout and sample code for creating a
remote view.
To use a remote view hierarchy in a notification, see Notification.contentView.
Because the remote view hierarchy belongs to another process, you cannot call methods on it
directly, but you can call methods on the RemoteViews
object to update views in the
heirarchy by ID. To reference a view inside the layout, use the
Titanium.App.Android.R object to reference the view's ID. For example, if you have a
view with the ID notify_imageview
, you can refer to it using:
Ti.App.Android.R.id.notify_imageview
See also:
RemoteViews in the Android Developer Reference.
XML Layouts in the Android Developer Guide.
The following code excerpt creates a RemoteViews
object based on a custom layout
called custom_layout.xml
, and set a label's text.
var AppR = Ti.App.Android.R;
var customLayout = Ti.Android.createRemoteViews({ layoutId: AppR.layout.custom_layout });
customLayout.setTextViewText(AppR.id.custom_text, "Click Me!");
This example uses a simple custom layout:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<TextView android:id="@+id/custom_text"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="#ffffff"
android:textColor="#aaff0000"
android:textStyle="italic"
android:gravity="center"
android:text="Hello, I am a TextView" />
</LinearLayout>
The layout file for this example must be placed in
platform/android/res/layout/custom_layout.xml
.
The name of the API that this proxy corresponds to.
The name of the API that this proxy corresponds to.
The value of this property is the fully qualified name of the API. For example, Button
returns Ti.UI.Button
.
Indicates if the proxy will bubble an event to its parent.
Some proxies (most commonly views) have a relationship to other proxies, often established by the add() method. For example, for a button added to a window, a click event on the button would bubble up to the window. Other common parents are table sections to their rows, table views to their sections, and scrollable views to their views. Set this property to false to disable the bubbling to the proxy's parent.
Default: true
Android layout resource ID for the view to display. Required.
To define a custom layout resource in your application, the XML layout file
should be placed in platform/android/res/layout
folder inside your project folder.
Use Titanium.App.Android.R to reference the ID of the layout.
The Window or TabGroup whose Activity lifecycle should be triggered on the proxy.
The Window or TabGroup whose Activity lifecycle should be triggered on the proxy.
If this property is set to a Window or TabGroup, then the corresponding Activity lifecycle event callbacks will also be called on the proxy. Proxies that require the activity lifecycle will need this property set to the appropriate containing Window or TabGroup.
Package name that the resource ID lives in. Optional.
Adds the specified callback as an event listener for the named event.
Name of the event.
Callback function to invoke when the event is fired.
Applies the properties to the proxy.
Properties are supplied as a dictionary. Each key-value pair in the object is applied to the proxy such that myproxy[key] = value.
A dictionary of properties to apply.
Fires a synthesized event to any registered listeners.
Name of the event.
A dictionary of keys and values to add to the Titanium.Event object sent to the listeners.
Removes the specified callback as an event listener for the named event.
Multiple listeners can be registered for the same event, so the
callback
parameter is used to determine which listener to remove.
When adding a listener, you must save a reference to the callback function in order to remove the listener later:
var listener = function() { Ti.API.info("Event listener called."); }
window.addEventListener('click', listener);
To remove the listener, pass in a reference to the callback function:
window.removeEventListener('click', listener);
Name of the event.
Callback function to remove. Must be the same function passed to addEventListener
.
Calls a method taking a single boolean
argument on a view in the remote view
hierarchy. See Android's documentation for
setBoolean.
Resource ID of the view to invoke the method on. Application-specific resource IDs can be specified using Titanium.App.Android.R.
Name of the method to call.
Value to pass to the method.
Sets the value of the bubbleParent property.
New value for the property.
Sets the base time, format string, and started flag for a chronometer in the remote view hierarchy.
See Android's documentation for setChronometer.
Resource ID of the Chronometer to update. Application-specific resource IDs can be specified using Titanium.App.Android.R.
Time at which the timer would have read 0:00.
Chronometer format string, or null
to simply display the timer value.
True if you want the clock to be started, false if not.
Calls a method taking a single double
argument on a view in the remote view
hierarchy.
See Android's documentation for setDouble.
Resource ID of the view to update. Application-specific resource IDs can be specified using Titanium.App.Android.R.
Name of the method to call.
Value to pass to the method.
Sets the image for an image view in the remote view hierarchy using an Android drawable resource.
See Android's documentation for setImageViewResource.
Resource ID of the ImageView
to update.
Application-specific resource IDs can be specified using Titanium.App.Android.R.
Resource ID of the new image. Application-specific resource IDs can be specified using Titanium.App.Android.R.
Sets the image for an image view in the remote view hierarchy using a URI.
This method supports supports both Android and Titanium URLs.
See Android's documentation for setImageViewUri.
Resource ID of the ImageView
to update.
Application-specific resource IDs can be specified using Titanium.App.Android.R.
URI of the image (both Android and Titanium URLs are supported).
Calls a method taking a single int
argument on a view in the remote view hierarchy.
See Android's documentation for setInt
Resource ID of the view to update. Application-specific resource IDs can be specified using Titanium.App.Android.R.
Name of the method to call.
Value to pass to the method.
Sets the value of the layoutId property.
New value for the property.
Sets the value of the lifecycleContainer property.
New value for the property.
Launches a Titanium.Android.PendingIntent when the specified view is clicked.
See Android's documentation for setOnClickPendingIntent.
Resource ID of the view to add a click listener to. Application-specific resource IDs can be specified using Titanium.App.Android.R.
The PendingIntent
to execute when this view is clicked.
Sets the value of the packageName property.
New value for the property.
Sets the progress, max value, and indeterminate flag of a progress bar in the remote view hierarchy.
See Android's documentation for setProgressBar.
Resource ID of the progress bar to update. Application-specific resource IDs can be specified using Titanium.App.Android.R.
The new maximum value of the progress bar.
The new progress value of the progress bar (from 0..max
).
Determines whether the progress bar is indeterminate.
If true
, the progress bar displays an infinite looping animation.
Calls a method taking a single String argument on a view in the remote view hierarchy.
See Android's documentation for setString.
Resource ID of the view to update. Application-specific resource IDs can be specified using Titanium.App.Android.R.
Name of the method to call.
String to pass to the method.
Sets the text color of a view in the remote view hierarchy.
See Android's documentation for setTextColor.
Resource ID of the view to update. Application-specific resource IDs can be specified using Titanium.App.Android.R.
Color as an integer.
Sets the text of a text view in the remote view hierarchy.
See Android's documentation for setTextViewText.
Resource ID of the text view to update. Application-specific resource IDs can be specified using Titanium.App.Android.R.
New text for the text view.
Calls a method taking one URI on a view in the remote view hierarchy.
See Android's documentation for setUri.
Resource ID of the view to update. Application-specific resource IDs can be specified using Titanium.App.Android.R.
Name of the method to call.
URI (as a string) to pass to the method.
Sets the visibility of a view in the remote view hierarchy.
See Android's documentation for setViewVisibility
Resource ID of the view to show or hide. Application-specific resource IDs can be specified using Titanium.App.Android.R.
The visibility. Either 0
(VISIBLE), 4
(INVISIBLE) or 8
(GONE).