com.smartdevicelink.proxy.rpc.Show Maven / Gradle / Ivy
/*
* Copyright (c) 2017 - 2019, SmartDeviceLink Consortium, Inc.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
*
* Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following
* disclaimer in the documentation and/or other materials provided with the
* distribution.
*
* Neither the name of the SmartDeviceLink Consortium, Inc. nor the names of its
* contributors may be used to endorse or promote products derived from this
* software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
package com.smartdevicelink.proxy.rpc;
import com.smartdevicelink.protocol.enums.FunctionID;
import com.smartdevicelink.proxy.RPCRequest;
import com.smartdevicelink.proxy.rpc.enums.TextAlignment;
import java.util.Hashtable;
import java.util.List;
/**
* Updates the application's display text area, regardless of whether or not
* this text area is visible to the user at the time of the request. The
* application's display text area remains unchanged until updated by subsequent
* calls to Show
*
* The content of the application's display text area is visible to the user
* when the application's {@linkplain com.smartdevicelink.proxy.rpc.enums.HMILevel}
* is FULL or LIMITED, and the
* {@linkplain com.smartdevicelink.proxy.rpc.enums.SystemContext}=MAIN and no
* {@linkplain Alert} is in progress
*
* The Show operation cannot be used to create an animated scrolling screen. To
* avoid distracting the driver, Show commands cannot be issued more than once
* every 4 seconds. Requests made more frequently than this will be rejected
*
* HMILevel needs to be FULL, LIMITED or BACKGROUND
*
* Parameter List
*
*
* Param Name
* Type
* Description
* Req.
* Notes
* Version Available
*
*
* mainField1
* String
* Text to be displayed in a single-line display, or in the upper display line in a two-line display.
* N
* If this parameter is omitted, the text of mainField1 does not change. If this parameter is an empty string, the field will be cleared. Maxlength = 500
* SmartDeviceLink 1.0
*
*
* mainField2
* String
* Text to be displayed on the second display line of a two-line display.
* N
* If this parameter is omitted, the text of mainField2 does not change.
If this parameter is an empty string, the field will be cleared.
If provided and the display is a single-line display, the parameter is ignored.
Maxlength = 500
* SmartDeviceLink 1.0
*
*
* mainField3
* String
* Text to be displayed on the first display line of the second page.
* N
* If this parameter is omitted, the text of mainField3 does not change.
If this parameter is an empty string, the field will be cleared.
If provided and the display is a single-line display, the parameter is ignored.
Maxlength = 500
* SmartDeviceLink 2.0
*
*
* mainField4
* String
* Text to be displayed on the second display line of the second page.
* N
* If this parameter is omitted, the text of mainField4 does not change.
If this parameter is an empty string, the field will be cleared.
If provided and the display is a single-line display, the parameter is ignored.
Maxlength = 500
* SmartDeviceLink 2.0
*
*
* alignment
* TextAlignment
* Specifies how mainField1 and mainField2 text should be aligned on display.
* N
* Applies only to mainField1 and mainField2 provided on this call, not to what is already showing in display.
If this parameter is omitted, text in both mainField1 and mainField2 will be centered.
Has no effect with navigation display
* SmartDeviceLink 1.0
*
*
* statusBar
* String
* The text is placed in the status bar area.
* N
* Note: The status bar only exists on navigation displays
If this parameter is omitted, the status bar text will remain unchanged.
If this parameter is an empty string, the field will be cleared.
If provided and the display has no status bar, this parameter is ignored.
Maxlength = 500
* SmartDeviceLink 1.0
*
*
* mediaClock
* String
* Text value for MediaClock field. Has to be properly formatted by Mobile App according to the module's capabilities. If this text is set, any automatic media clock updates previously set with SetMediaClockTimer will be stopped.
* N
* {"string_min_length": 0, "string_max_length": 500}
* SmartDeviceLink 1.0.0
*
*
* Deprecated in SmartDeviceLink 7.1.0
*
*
* mediaTrack
* String
* Array of one or more TTSChunk elements specifying the help prompt used in an interaction started by PTT.
* N
* If parameter is omitted, the track field remains unchanged.
If an empty string is provided, the field will be cleared.
This field is only valid for media applications on navigation displays.
Maxlength = 500
* SmartDeviceLink 1.0
*
*
* graphic
* Image
* Image to be shown on supported displays.
* N
* If omitted on supported displays, the displayed graphic shall not change.
* SmartDeviceLink 2.0
*
*
* secondaryGraphic
* Image
* Image struct determining whether static or dynamic secondary image to display in app.
If omitted on supported displays, the displayed secondary graphic shall not change.
* N
*
* SmartDeviceLink 2.3.2
*
*
* softButtons
* SoftButton
* Soft buttons as defined by the App
* N
* If omitted on supported displays, the currently displayed SoftButton values will not change.
Array Minsize: 0; Array Maxsize: 8
* SmartDeviceLink 2.0
*
*
* customPresets
* String
* Custom presets as defined by the App.
* N
* If omitted on supported displays, the presets will be shown as not defined.
Minsize: 0; Maxsize: 6
* SmartDeviceLink 2.0
*
*
* templateTitle
* String
* The title of the new template that will be displayed.
* N
* How this will be displayed is dependent on the OEM design and implementation of the template..
Minsize: 0; Maxsize: 100
* SmartDeviceLink 6.0.0
*
*
*
* Response
*
* Non-default Result Codes:
* SUCCESS
* INVALID_DATA
* OUT_OF_MEMORY
* TOO_MANY_PENDING_REQUESTS
* APPLICATION_NOT_REGISTERED
* GENERIC_ERROR
* REJECTED
* DISALLOWED
* UNSUPPORTED_RESOURCE
* ABORTED
*
* @see Alert
* @see SetMediaClockTimer
* @since SmartDeviceLink 1.0
*/
public class Show extends RPCRequest {
public static final String KEY_GRAPHIC = "graphic";
public static final String KEY_CUSTOM_PRESETS = "customPresets";
public static final String KEY_MAIN_FIELD_1 = "mainField1";
public static final String KEY_MAIN_FIELD_2 = "mainField2";
public static final String KEY_MAIN_FIELD_3 = "mainField3";
public static final String KEY_MAIN_FIELD_4 = "mainField4";
public static final String KEY_STATUS_BAR = "statusBar";
/**
* @since SmartDeviceLink 1.0.0
* @deprecated in SmartDeviceLink 7.1.0
*/
@Deprecated
public static final String KEY_MEDIA_CLOCK = "mediaClock";
public static final String KEY_ALIGNMENT = "alignment";
public static final String KEY_MEDIA_TRACK = "mediaTrack";
public static final String KEY_SECONDARY_GRAPHIC = "secondaryGraphic";
public static final String KEY_SOFT_BUTTONS = "softButtons";
public static final String KEY_METADATA_TAGS = "metadataTags";
public static final String KEY_WINDOW_ID = "windowID";
public static final String KEY_TEMPLATE_CONFIGURATION = "templateConfiguration";
public static final String KEY_TEMPLATE_TITLE = "templateTitle";
/**
* Constructs a new Show object
*/
public Show() {
super(FunctionID.SHOW.toString());
}
/**
* Constructs a new Show object indicated by the Hashtable parameter
*
*
* @param hash The Hashtable to use
*/
public Show(Hashtable hash) {
super(hash);
}
/**
* Gets the text displayed in a single-line display, or in the upper display
* line in a two-line display
*
* @return String -a String value representing the text displayed in a
* single-line display, or in the upper display line in a two-line
* display
*/
public String getMainField1() {
return getString(KEY_MAIN_FIELD_1);
}
/**
* Sets the text displayed in a single-line display, or in the upper display
* line in a two-line display
*
* @param mainField1 the String value representing the text displayed in a
* single-line display, or in the upper display line in a
* two-line display
*
* Notes:
*
* - If this parameter is omitted, the text of mainField1 does
* not change
* - If this parameter is an empty string, the field will be
* cleared
*
*/
public Show setMainField1(String mainField1) {
setParameters(KEY_MAIN_FIELD_1, mainField1);
return this;
}
/**
* Gets the text displayed on the second display line of a two-line display
*
* @return String -a String value representing the text displayed on the
* second display line of a two-line display
*/
public String getMainField2() {
return getString(KEY_MAIN_FIELD_2);
}
/**
* Sets the text displayed on the second display line of a two-line display
*
* @param mainField2 the String value representing the text displayed on the second
* display line of a two-line display
*
* Notes:
*
* - If this parameter is omitted, the text of mainField2 does
* not change
* - If this parameter is an empty string, the field will be
* cleared
* - If provided and the display is a single-line display, the
* parameter is ignored
* - Maxlength = 500
*
*/
public Show setMainField2(String mainField2) {
setParameters(KEY_MAIN_FIELD_2, mainField2);
return this;
}
/**
* Gets the text displayed on the first display line of the second page
*
* @return String -a String value representing the text displayed on the
* first display line of the second page
* @since SmartDeviceLink 2.0
*/
public String getMainField3() {
return getString(KEY_MAIN_FIELD_3);
}
/**
* Sets the text displayed on the first display line of the second page
*
* @param mainField3 the String value representing the text displayed on the first
* display line of the second page
*
* Notes:
*
* - If this parameter is omitted, the text of mainField3 does
* not change
* - If this parameter is an empty string, the field will be
* cleared
* - If provided and the display is a single-line display, the
* parameter is ignored
* - Maxlength = 500
*
* @since SmartDeviceLink 2.0
*/
public Show setMainField3(String mainField3) {
setParameters(KEY_MAIN_FIELD_3, mainField3);
return this;
}
/**
* Gets the text displayed on the second display line of the second page
*
* @return String -a String value representing the text displayed on the
* first display line of the second page
* @since SmartDeviceLink 2.0
*/
public String getMainField4() {
return getString(KEY_MAIN_FIELD_4);
}
/**
* Sets the text displayed on the second display line of the second page
*
* @param mainField4 the String value representing the text displayed on the second
* display line of the second page
*
* Notes:
*
* - If this parameter is omitted, the text of mainField4 does
* not change
* - If this parameter is an empty string, the field will be
* cleared
* - If provided and the display is a single-line display, the
* parameter is ignored
* - Maxlength = 500
*
* @since SmartDeviceLink 2.0
*/
public Show setMainField4(String mainField4) {
setParameters(KEY_MAIN_FIELD_4, mainField4);
return this;
}
/**
* Gets the alignment that Specifies how mainField1 and mainField2 text
* should be aligned on display
*
* @return TextAlignment -an Enumeration value
*/
public TextAlignment getAlignment() {
return (TextAlignment) getObject(TextAlignment.class, KEY_ALIGNMENT);
}
/**
* Sets the alignment that Specifies how mainField1 and mainField2 text
* should be aligned on display
*
* @param alignment an Enumeration value
*
* Notes:
*
* - Applies only to mainField1 and mainField2 provided on this
* call, not to what is already showing in display
* - If this parameter is omitted, text in both mainField1 and
* mainField2 will be centered
* - Has no effect with navigation display
*
*/
public Show setAlignment(TextAlignment alignment) {
setParameters(KEY_ALIGNMENT, alignment);
return this;
}
/**
* Gets text in the Status Bar
*
* @return String -the value in the Status Bar
*/
public String getStatusBar() {
return getString(KEY_STATUS_BAR);
}
/**
* Sets text in the Status Bar
*
* @param statusBar a String representing the text you want to add in the Status
* Bar
*
* Notes: The status bar only exists on navigation
* displays
*
* - If this parameter is omitted, the status bar text will
* remain unchanged
* - If this parameter is an empty string, the field will be
* cleared
* - If provided and the display has no status bar, this
* parameter is ignored
*
*/
public Show setStatusBar(String statusBar) {
setParameters(KEY_STATUS_BAR, statusBar);
return this;
}
/**
* Gets the mediaClock.
*
* @return String Text value for MediaClock field. Has to be properly formatted by Mobile App according to
* the module's capabilities. If this text is set, any automatic media clock updates
* previously set with SetMediaClockTimer will be stopped.
* {"string_min_length": 0, "string_max_length": 500}
* @since SmartDeviceLink 1.0.0
* @deprecated in SmartDeviceLink 7.1.0
*/
@Deprecated
public String getMediaClock() {
return getString(KEY_MEDIA_CLOCK);
}
/**
* Sets the mediaClock.
*
* @param mediaClock Text value for MediaClock field. Has to be properly formatted by Mobile App according to
* the module's capabilities. If this text is set, any automatic media clock updates
* previously set with SetMediaClockTimer will be stopped.
* {"string_min_length": 0, "string_max_length": 500}
* @since SmartDeviceLink 1.0.0
* @deprecated in SmartDeviceLink 7.1.0
*/
@Deprecated
public Show setMediaClock(String mediaClock) {
setParameters(KEY_MEDIA_CLOCK, mediaClock);
return this;
}
/**
* Gets the text in the track field
*
* @return String -a String displayed in the track field
*/
public String getMediaTrack() {
return getString(KEY_MEDIA_TRACK);
}
/**
* Sets the text in the track field
*
* @param mediaTrack a String value displayed in the track field
*
* Notes:
*
* - If parameter is omitted, the track field remains unchanged
* - If an empty string is provided, the field will be cleared
* - This field is only valid for media applications on navigation displays
*
*/
public Show setMediaTrack(String mediaTrack) {
setParameters(KEY_MEDIA_TRACK, mediaTrack);
return this;
}
/**
* Sets an image to be shown on supported displays
*
* @param graphic the value representing the image shown on supported displays
*
* Notes: If omitted on supported displays, the displayed
* graphic shall not change
* @since SmartDeviceLink 2.0
*/
public Show setGraphic(Image graphic) {
setParameters(KEY_GRAPHIC, graphic);
return this;
}
/**
* Gets an image to be shown on supported displays
*
* @return Image -the value representing the image shown on supported
* displays
* @since SmartDeviceLink 2.0
*/
public Image getGraphic() {
return (Image) getObject(Image.class, KEY_GRAPHIC);
}
public Show setSecondaryGraphic(Image secondaryGraphic) {
setParameters(KEY_SECONDARY_GRAPHIC, secondaryGraphic);
return this;
}
public Image getSecondaryGraphic() {
return (Image) getObject(Image.class, KEY_SECONDARY_GRAPHIC);
}
/**
* Gets the Soft buttons defined by the App
*
* @return List -a List value representing the Soft buttons
* defined by the App
* @since SmartDeviceLink 2.0
*/
@SuppressWarnings("unchecked")
public List getSoftButtons() {
return (List) getObject(SoftButton.class, KEY_SOFT_BUTTONS);
}
/**
* Sets the Soft buttons defined by the App
*
* @param softButtons a List value representing the Soft buttons defined by the
* App
*
* Notes:
*
* - If omitted on supported displays, the currently displayed
* SoftButton values will not change
* - Array Minsize: 0
* - Array Maxsize: 8
*
* @since SmartDeviceLink 2.0
*/
public Show setSoftButtons(List softButtons) {
setParameters(KEY_SOFT_BUTTONS, softButtons);
return this;
}
/**
* Gets the Custom Presets defined by the App
*
* @return List - a List value representing the Custom presets
* defined by the App
* @since SmartDeviceLink 2.0
*/
@SuppressWarnings("unchecked")
public List getCustomPresets() {
return (List) getObject(String.class, KEY_CUSTOM_PRESETS);
}
/**
* Sets the Custom Presets defined by the App
*
* @param customPresets a List value representing the Custom Presets defined by the
* App
*
*
* - If omitted on supported displays, the presets will be shown as not defined
* - Array Minsize: 0
* - Array Maxsize: 6
*
* @since SmartDeviceLink 2.0
*/
public Show setCustomPresets(List customPresets) {
setParameters(KEY_CUSTOM_PRESETS, customPresets);
return this;
}
/**
* Sets text field metadata defined by the App
*
* @param metadataTags A Struct containing metadata pertaining to the main text fields
*
*
* @since SmartDeviceLink 4.5.0
*/
public Show setMetadataTags(MetadataTags metadataTags) {
setParameters(KEY_METADATA_TAGS, metadataTags);
return this;
}
/**
* Gets text field metadata defined by the App
*
* @return metadataTags - App defined metadata information. See MetadataTags. Uses mainField1, mainField2, mainField3, mainField4.
* If omitted on supported displays, the currently set metadata tags will not change.
* If any text field contains no tags or the none tag, the metadata tag for that textfield should be removed.
* @since SmartDeviceLink 4.5.0
*/
public MetadataTags getMetadataTags() {
return (MetadataTags) getObject(MetadataTags.class, KEY_METADATA_TAGS);
}
/**
* Sets the windowID. It's a unique ID to identify the window.
* If this param is not included, it will be assumed that this request is specifically for the main window on the main display.
* See PredefinedWindows enum.
*
* @param windowID A unique ID to identify the window. The value of '0' will always be the default main window on the main display and should not be used in this context as it will already be created for the app. See PredefinedWindows enum. Creating a window with an ID that is already in use will be rejected with `INVALID_ID`.
* @since 6.0
*/
public Show setWindowID(Integer windowID) {
setParameters(KEY_WINDOW_ID, windowID);
return this;
}
/**
* Gets the windowID.
*
* @return int -an int value representing the windowID.
*/
public Integer getWindowID() {
return getInteger(KEY_WINDOW_ID);
}
/**
* Gets the templateConfiguration.
*
* @return TemplateConfiguration
* @since 6.0
*/
public TemplateConfiguration getTemplateConfiguration() {
return (TemplateConfiguration) getObject(TemplateConfiguration.class, KEY_TEMPLATE_CONFIGURATION);
}
/**
* Sets the templateConfiguration. It's used to set an alternate template layout to a window.
*
* @param templateConfiguration
*/
public Show setTemplateConfiguration(TemplateConfiguration templateConfiguration) {
setParameters(KEY_TEMPLATE_CONFIGURATION, templateConfiguration);
return this;
}
/**
* Sets the title of the new template that will be displayed.
* How this will be displayed is dependent on the OEM design and implementation of the template.
*
* @param templateTitle the title of the new template that will be displayed
*
*
* - Minlength: 0
* - Maxlength: 100
*
* @since SmartDeviceLink 6.0.0
*/
public Show setTemplateTitle(String templateTitle) {
setParameters(KEY_TEMPLATE_TITLE, templateTitle);
return this;
}
/**
* Gets the title of the new template that will be displayed
* How this will be displayed is dependent on the OEM design and implementation of the template.
*
* @return templateTitle - String value that represents the title of the new template that will be displayed
* @since SmartDeviceLink 6.0.0
*/
public String getTemplateTitle() {
return getString(KEY_TEMPLATE_TITLE);
}
}