Class BrowserComponent
- All Implemented Interfaces:
Animation, Editable, StyleListener, Iterable<Component>
The browser component is an interface to an embeddable native platform browser on platforms that support embedding the native browser in place, if you need wide compatibility and flexibility you should check out the HTMLComponent which provides a lightweight 100% cross platform web component.
This component will only work on platforms that support embedding a native browser which exclude earlier versions of Blackberry devices and J2ME devices.
Its recommended that you place this component in a fixed position (none scrollable) on the screen without other focusable components to prevent confusion between focus authority and allow the component to scroll itself rather than CodenameOne making that decision for it.
On Android this component might show a native progress indicator dialog. You can disable that functionality
using the Display.getInstance().setProperty("WebLoadingHidden", "true"); call.
The following code shows the basic usage of the BrowserComponent:
Form hi = new Form("Browser", new BorderLayout());
BrowserComponent browser = new BrowserComponent();
browser.setURL("https://www.codenameone.com/");
hi.add(BorderLayout.CENTER, browser);
Debugging on Android
You can use Chrome's remote debugging features to debug the contents of a BrowserComponent. On Android 4.4 (KitKat) and higher, you will need to define the "android.webContentsDebuggingEnabled" display property in order for this to work. You can define this inside your app's init() method:
java Display.getInstance().setProperty("android.webContentsDebuggingEnabled", "true");
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic classA wrapper class for a literal javascript expression that can be passed as an arg injava.lang.Object[]).classA thin wrapper around a Javascript variable that makes it easier to call methods on that variable.static classA wrapper class for a Javascript value that is returned via thecom.codename1.util.Callback)method.static enumEnum with the possible types for aJSRefobject. -
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final StringBrowser property key to control whether links withtarget="_blank"ortarget="_new"should be followed in the current browser view.static final StringString constant for web event listenercom.codename1.ui.events.ActionListener)static final StringString constant for web event listenercom.codename1.ui.events.ActionListener)static final StringString constant for web event listener.static final StringString constant for web event listenercom.codename1.ui.events.ActionListener)Fields inherited from class Component
BASELINE, BOTTOM, BRB_CENTER_OFFSET, BRB_CONSTANT_ASCENT, BRB_CONSTANT_DESCENT, BRB_OTHER, CENTER, CROSSHAIR_CURSOR, DEFAULT_CURSOR, DRAG_REGION_IMMEDIATELY_DRAG_X, DRAG_REGION_IMMEDIATELY_DRAG_XY, DRAG_REGION_IMMEDIATELY_DRAG_Y, DRAG_REGION_LIKELY_DRAG_X, DRAG_REGION_LIKELY_DRAG_XY, DRAG_REGION_LIKELY_DRAG_Y, DRAG_REGION_NOT_DRAGGABLE, DRAG_REGION_POSSIBLE_DRAG_X, DRAG_REGION_POSSIBLE_DRAG_XY, DRAG_REGION_POSSIBLE_DRAG_Y, E_RESIZE_CURSOR, HAND_CURSOR, LEFT, MOVE_CURSOR, N_RESIZE_CURSOR, NE_RESIZE_CURSOR, NW_RESIZE_CURSOR, RIGHT, S_RESIZE_CURSOR, SE_RESIZE_CURSOR, SW_RESIZE_CURSOR, TEXT_CURSOR, TOP, W_RESIZE_CURSOR, WAIT_CURSORModifier and TypeFieldDescriptionstatic final intAlignment to the baseline constraintstatic final intBox-orientation constant used to specify the bottom of a box.static final intBaseline resize behavior constant used to properly align components.static final intBaseline resize behavior constant used to properly align components.static final intBaseline resize behavior constant used to properly align components.static final intBaseline resize behavior constant used to properly align components.static final intIndicates a Component center alignmentstatic final intThe crosshair cursor type.static final intThe default cursorstatic final intUsed by getDragRegionStatus to indicate immediate dragabilitystatic final intUsed by getDragRegionStatus to indicate immediate dragabilitystatic final intUsed by getDragRegionStatus to indicate immediate dragabilitystatic final intUsed by getDragRegionStatus to indicate likely dragabilitystatic final intUsed by getDragRegionStatus to indicate likely dragabilitystatic final intUsed by getDragRegionStatus to indicate likely dragabilitystatic final intUsed by getDragRegionStatus to indicate no dragabilitystatic final intUsed by getDragRegionStatus to indicate limited dragabilitystatic final intUsed by getDragRegionStatus to indicate limited dragabilitystatic final intUsed by getDragRegionStatus to indicate limited dragabilitystatic final intThe east-resize cursor type.static final intThe hand cursor type.static final intBox-orientation constant used to specify the left side of a box.static final intThe move cursor type.static final intThe north-resize cursor type.static final intThe north-east-resize cursor type.static final intThe north-west-resize cursor type.static final intBox-orientation constant used to specify the right side of a box.static final intThe south-resize cursor type.static final intThe south-east-resize cursor type.static final intThe south-west-resize cursor type.static final intThe text cursor type.static final intBox-orientation constant used to specify the top of a box.static final intThe west-resize cursor type.static final intThe wait cursor type. -
Constructor Summary
ConstructorsConstructorDescriptionThis constructor will work as expected when a browser component is supported, see isNativeBrowserSupported() -
Method Summary
Modifier and TypeMethodDescriptionvoidAdds a navigation callback.voidaddJSCallback(String installJs, SuccessCallback<BrowserComponent.JSRef> callback) Registers a Java method as a callback in javascript.voidaddJSCallback(String installJs, Object[] params, SuccessCallback<BrowserComponent.JSRef> callback) Registers Java method as a callback in Javascript.voidaddWebEventListener(String type, ActionListener listener) Adds a listener to the given event type name, event type names are platform specific but some must be fired for all platforms and will invoke the action listener when the appropriate event loadsvoidback()Navigates back in the historyAsync method for capturing a screenshot of the browser content.voidClears navigation historystatic StringcreateDataURI(byte[] data, String mime) This method creates a data URI which allows developers creating HTML for local use to embed local images into the HTML by appending them as a URI.createJSProxy(String javascriptExpression) Creates a proxy for a Javascript object that makes it easier to call methods, retrieve, and manipulate properties on the object.protected voidInvoked to indicate that the component initialization is being reversed since the component was detached from the container hierarchy.voiddestroy()Release native resources of this Browser Componentvoidexecute(int timeout, String js, SuccessCallback<BrowserComponent.JSRef> callback) Execute javascript with a timeout.voidexecute(int timeout, String js, Object[] params, SuccessCallback<BrowserComponent.JSRef> callback) Executes Javascript expression.voidExecutes the given JavaScript string within the current contextvoidexecute(String js, SuccessCallback<BrowserComponent.JSRef> callback) Asynchronously executes the provided javascript expression.voidExecutes given javascript string within current context.voidexecute(String js, Object[] params, SuccessCallback<BrowserComponent.JSRef> callback) Executes Javascript expression.executeAndReturnString(String javaScript) Executes the given JavaScript and returns a result string from the underlying platform where applicable.executeAndReturnString(String javaScript, Object[] params) Executes the given javascript and returns the result string from the underlying platform.executeAndWait(int timeout, String js) This uses invokeAndBlock to wait for the result of the given javascript expression.executeAndWait(int timeout, String js, Object... params) This uses invokeAndBlock to wait for the result of the given javascript expression.executeAndWait(String js) This uses invokeAndBlock to wait for the result of the given javascript expression.executeAndWait(String js, Object... params) This uses invokeAndBlock to wait for the result of the given javascript expression.voidexposeInJavaScript(Object o, String name) Allows exposing the given object to JavaScript code so the JavaScript code can invoke methods and access fields on the given object.booleanFires all of the registered browser navigation callbacks against the provided URL.voidfireWebEvent(String type, ActionEvent ev) Used internally by the implementation to fire an event from the native browser widgetvoidforward()Navigates forward in the historyThe browser navigation callback interface allows handling a case where a URL invocation can be delegated to Java code.getTitle()The page titlegetURL()The page URLbooleanhasBack()Indicates whether back is currently availablebooleanIndicates whether forward is currently availablestatic StringinjectParameters(String jsExpression, Object... params) Injects parameters into a Javascript string expression.booleanIndicates if debug mode is set (might have no effect though)booleanChecks if javascript callbacks are run on the EDT.static booleanReturns true if the platform supports embedding a native browser componentbooleanThis method is unreliable and is only here for consistency with setNativeScrollingEnabled.booleanThis method is unreliable and is only here for consistency with setPinchToZoomEnabled, it will not return whether the platform supports pinch since this is very hard to detect properly.booleanReturns true if the methodjava.util.Map)is supportedvoidpostMessage(String message, String targetOrigin) Calls the postMessage() method on the webpage's window object.voidputClientProperty(String key, Object value) Sets a client property on this component.ready()Returns a promise that will complete when the browser component is "ready".ready(int timeout) Returns a promise that will complete when the browser component is "ready".ready(SuccessCallback<BrowserComponent> onReady) Registers a callback to be run when the BrowserComponent is "ready".voidreload()Reload the current pagevoidRemoves a navigation callback.voidremoveJSCallback(Callback<BrowserComponent.JSRef> callback) Removes a JS callback that was added via thecom.codename1.util.SuccessCallback)method.voidvoidremoveWebEventListener(String type, ActionListener listener) Removes the listener, see addWebEventListener for detailsvoidSet the browser navigation callback which allows handling a case where a URL invocation can be delegated to Java code.voidsetDebugMode(boolean mode) Toggles debug mode for the browser component which helps detect coding errors in the JavaScript bridge logicvoidsetFireCallbacksOnEdt(boolean edt) Sets whether javascript callbacks should be run on the EDT.voidsetNativeScrollingEnabled(boolean b) This flag allows disabling the native browser scrolling on platforms that support itvoidShows the given HTML in the native viewervoidsetPinchToZoomEnabled(boolean e) Some platforms require that you enable pinch to zoom explicitly.voidsetProperty(String key, Object value) This method allows customizing the properties of a web view in various ways including platform specific settings.voidSets the page URL.voidSets the page URL, jar: URL's must be supported by the implementationvoidSets the page URL, jar: URL's must be supported by the implementation.voidSets the page URL.voidsetURLHierarchy(String url) Sets the page URL while respecting the hierarchy of the htmlvoidstop()Cancel the loading of the current pagevoidUses invokeAndBlock to wait until the BrowserComponent is ready.Methods inherited from class Container
add, add, add, add, add, add, addAll, addComponent, addComponent, addComponent, addComponent, animateHierarchy, animateHierarchyAndWait, animateHierarchyFade, animateHierarchyFadeAndWait, animateLayout, animateLayoutAndWait, animateLayoutFade, animateLayoutFadeAndWait, animateUnlayout, animateUnlayoutAndWait, applyRTL, calcPreferredSize, cancelRepaints, clearClientProperties, constrainHeightWhenScrollable, constrainWidthWhenScrollable, contains, createAnimateHierarchy, createAnimateHierarchyFade, createAnimateLayout, createAnimateLayoutFade, createAnimateLayoutFadeAndWait, createAnimateMotion, createAnimateUnlayout, createReplaceTransition, dragInitiated, drop, encloseIn, encloseIn, findDropTargetAt, findFirstFocusable, fireClicked, flushReplace, forceRevalidate, getBottomGap, getChildrenAsList, getClosestComponentTo, getComponentAt, getComponentAt, getComponentCount, getComponentIndex, getGridPosX, getGridPosY, getLayout, getLayoutHeight, getLayoutWidth, getLeadComponent, getLeadParent, getResponderAt, getSafeAreaRoot, getScrollIncrement, getSideGap, getUIManager, initLaf, invalidate, isEnabled, isSafeArea, isSafeAreaRoot, isScrollableX, isScrollableY, isSelectableInteraction, isSurface, iterator, iterator, keyPressed, keyReleased, layoutContainer, morph, morphAndWait, paint, paintComponentBackground, paintGlass, paramString, pointerPressed, refreshTheme, removeAll, removeComponent, replace, replace, replaceAndWait, replaceAndWait, replaceAndWait, revalidate, revalidateLater, revalidateWithAnimationSafety, scrollComponentToVisible, setCellRenderer, setEnabled, setLayout, setLeadComponent, setSafeArea, setSafeAreaRoot, setScrollable, setScrollableX, setScrollableY, setScrollIncrement, setShouldCalcPreferredSize, setShouldLayout, setUIManager, updateTabIndicesModifier and TypeMethodDescriptionfinal ContainerSimpler version of addComponent that allows chaining the calls for shorter syntaxSimpler version of addComponent that allows chaining the calls for shorter syntaxSimpler version of addComponent that allows chaining the calls for shorter syntaxSimpler version of addComponent that allows chaining the calls for shorter syntaxSimpler version of addComponent that allows chaining the calls for shorter syntaxSimpler version of addComponent that allows chaining the calls for shorter syntaxIdentical to add(x).add(y) only with a shorter syntaxvoidaddComponent(int index, Component cmp) This method adds the Component at a specific index location in the Container Components array.voidaddComponent(int index, Object constraints, Component cmp) Adds a Component to the ContainervoidaddComponent(Component cmp) Adds a Component to the ContainervoidaddComponent(Object constraints, Component cmp) Adds a Component to the ContainervoidanimateHierarchy(int duration) Animates a pending hierarchy of components into place, this effectively replaces revalidate with a more visual form of animationvoidanimateHierarchyAndWait(int duration) Animates a pending hierarchy of components into place, this effectively replaces revalidate with a more visual form of animation.voidanimateHierarchyFade(int duration, int startingOpacity) Animates a pending hierarchy of components into place, this effectively replaces revalidate with a more visual form of animationvoidanimateHierarchyFadeAndWait(int duration, int startingOpacity) Animates a pending hierarchy of components into place, this effectively replaces revalidate with a more visual form of animation.voidanimateLayout(int duration) Animates a pending layout into place, this effectively replaces revalidate with a more visual form of animationvoidanimateLayoutAndWait(int duration) Animates a pending layout into place, this effectively replaces revalidate with a more visual form of animation.voidanimateLayoutFade(int duration, int startingOpacity) Animates a pending layout into place, this effectively replaces revalidate with a more visual form of animationvoidanimateLayoutFadeAndWait(int duration, int startingOpacity) Animates a pending layout into place, this effectively replaces revalidate with a more visual form of animation.voidanimateUnlayout(int duration, int opacity, Runnable callback) This method is the exact reverse of animateLayout, when completed it leaves the container in an invalid state.voidanimateUnlayoutAndWait(int duration, int opacity) This method is the exact reverse of animateLayoutAndWait, when completed it leaves the container in an invalid state.voidapplyRTL(boolean rtl) Invokes apply/setRTL recursively on all the children components of this containerprotected DimensionCalculates the preferred size based on component content.protected voidremove this component and it's children from the painting queuevoidClears all client properties from this Componentprotected booleanIndicates that children's widths should be calculated as if this component weren't scrollable-X, even when the component is scrollable Y.protected booleanIndicates that children's widths should be calculated as if this component weren't scrollable-X, even when the component is scrollable X.booleanReturns true if the given component is within the hierarchy of this containercreateAnimateHierarchy(int duration) Animates a pending hierarchy of components into place, this effectively replaces revalidate with a more visual form of animation.createAnimateHierarchyFade(int duration, int startingOpacity) Animates a pending hierarchy of components into place, this effectively replaces revalidate with a more visual form of animation.createAnimateLayout(int duration) Animates a pending layout into place, this effectively replaces revalidate with a more visual form of animationcreateAnimateLayoutFade(int duration, int startingOpacity) Animates a pending layout into place, this effectively replaces revalidate with a more visual form of animationcreateAnimateLayoutFadeAndWait(int duration, int startingOpacity) Animates a pending layout into place, this effectively replaces revalidate with a more visual form of animation.protected MotioncreateAnimateMotion(int start, int destination, int duration) Creates a motion object for animation, allows subclasses to replace the motion type used in animations (currently defaults to ease-in).createAnimateUnlayout(int duration, int opacity, Runnable callback) This method is the exact reverse of createAnimateLayout, when animation is completed it leaves the container in an invalid state.createReplaceTransition(Component current, Component next, Transition t) This method creates an animation component that replaces the current Component with the next Component.protected voidInvoked on the focus component to let it know that drag has started on the parent container for the case of a component that doesn't support scrollingvoidPerforms a drop operation of the component at the given X/Y location in coordinate space, this method should be overriden by subclasses to perform all of the logic related to moving a component, by default this method does nothing and so dragging a component and dropping it has no effectstatic ContainerShort-hand for enclosing multiple components in a container typically a box layoutstatic ContainerShort-hand for enclosing a component within a ContainerfindDropTargetAt(int x, int y) Recursively searches the container hierarchy for a drop targetFinds the first focusable Component on this Containerprotected voidWhen working in 3 softbutton mode "fire" key (center softbutton) is sent to this method in order to allow 3 button devices to work properly.voidFlushes ongoing replace operations to prevent two concurrent replace operations from colliding.voidA more powerful form of revalidate that recursively lays out the full hierarchyintReturns the gap to be left for the bottom scrollbar on the X axis.getChildrenAsList(boolean includeQueued) Gets the child components of this Container as a List.getClosestComponentTo(int x, int y) Very useful for touch events or drop events that need approximation more than accuracygetComponentAt(int index) Returns the Component at a given indexgetComponentAt(int x, int y) Returns a Component at coordinate (x, y).intReturns the number of componentsintReturns the Component index in the Containerprotected intThis method should be implemented correctly by subclasses to make snap to grid functionality work as expected.protected intThis method should be implemented correctly by subclasses to make snap to grid functionality work as expected.Returns the layout manager responsible for arranging this container.intReturns the height for layout manager purposes, this takes scrolling into consideration unlike the getHeight method.intReturns the width for layout manager purposes, this takes scrolling into consideration unlike the getWidth method.Returns the lead component for this hierarchy if such a component is definedReturns the lead container thats handling the leading, this is useful for a container hierarchy where the parent container might not be the leadergetResponderAt(int x, int y) Returns the top-most component that responds to pointer events at absolute coordinate (x, y).Gets the Safe area "root" container for this container.intGets the Container scroll incrementintReturns the gap to be left for the side scrollbar on the Y axis.This method should be used by the Component to retrieve the correct UIManager to work withprotected voidThis method initializes the Component defaults constantsvoidSame as setShouldCalcPreferredSize(true) but made accessible for layout managersbooleanIndicates whether component is enabled or disabled thus allowing us to prevent a component from receiving input events and indicate so visuallybooleanChecks if this container is a "safe area".booleanChecks if this container is a safe area root.booleanIndicates whether the component should/could scroll on the X axisbooleanIndicates whether the component should/could scroll on the Y axisprotected booleanThis method allows a component to indicate that it is interested in an "implicit" select command to appear in the "fire" button when 3 softbuttons are defined in a device.booleanChecks if this container acts as a Material Design surface.iterator()Part of the Iterable interface allowing us to do a for-each loop on Containeriterator(boolean includeQueued) Obtains an iterator that iterates over the children of this container.voidkeyPressed(int k) If this Component is focused, the key pressed event will call this methodvoidkeyReleased(int k) If this Component is focused, the key released event will call this methodvoidPerforms the layout of the container if a layout is necessaryvoidMorph is similar to the replace functionality where a component might be replaced with a component that isn't within the container.voidmorphAndWait(Component source, Component destination, int duration) Morph is similar to the replace functionality where a component might be replaced with a component that isn't within the container.voidThis method paints the Component on the screen, it should be overriden by subclasses to perform custom drawing or invoke the UI API's to let the PLAF perform the rendering.voidPaints this container background, skipping container background fill when fully obscured by children.protected voidThis method can be overriden by a component to draw on top of itself or its children after the component or the children finished drawing in a similar way to the glass pane but more refined per componentprotected StringReturns a string representing the state of this component.voidpointerPressed(int x, int y) If this Component is focused, the pointer pressed event will call this methodvoidrefreshTheme(boolean merge) Makes sure the component is up to date with the current theme, ONLY INVOKE THIS METHOD IF YOU CHANGED THE THEME!voidremove all Components from container, notice that removed component might still have a pending repaint in the queue that won't be removed.voidremoveComponent(Component cmp) removes a Component from the Container, notice that removed component might still have a pending repaint in the queue that won't be removed.voidreplace(Component current, Component next, Transition t) This method replaces the current Component with the next Component.voidreplace(Component current, Component next, Transition t, Runnable onFinish, int growSpeed) This method replaces the current Component with the next ComponentvoidreplaceAndWait(Component current, Component next, Transition t) This method replaces the current Component with the next Component.voidreplaceAndWait(Component current, Component next, Transition t, boolean dropEvents) This method replaces the current Component with the next Component.voidreplaceAndWait(Component current, Component next, Transition t, int layoutAnimationSpeed) This method replaces the current Component with the next Component.voidRe-layout the container, this is useful when we modify the container hierarchy and need to redo the layoutvoidRevalidates the container before the next paint cycle.voidRevalidates the container in a way that doesn't conflict with running animations.voidMakes sure the component is visible in the scroll if this container is scrollablevoidsetCellRenderer(boolean cellRenderer) Used as an optimization to mark that this component is currently being used as a cell renderervoidsetEnabled(boolean enabled) This method will recursively set all the Container chidrens to be enabled/disabled.voidSets the layout manager responsible for arranging this containerfinal voidsetLeadComponent(Component lead) Sets the lead component for this container, a lead component takes over the entire component hierarchy and receives all the events for the container hierarchy.voidsetSafeArea(boolean safeArea) Marks this container as a "safe area", meaning that it will automatically supply sufficient padding as necessary for its children to be laid out inside the safe area of the screen.voidsetSafeAreaRoot(boolean root) Set whether this container is a safe area root.voidsetScrollable(boolean scrollable) The equivalent of calling both setScrollableY and setScrollableXvoidsetScrollableX(boolean scrollableX) Sets whether the component should/could scroll on the X axisvoidsetScrollableY(boolean scrollableY) Sets whether the component should/could scroll on the Y axisvoidsetScrollIncrement(int scrollIncrement) Determines the scroll increment size of this Container.voidsetShouldCalcPreferredSize(boolean shouldCalcPreferredSize) Indicates the values within the component have changed and preferred size should be recalculatedprotected voidsetShouldLayout(boolean layout) Flags this container to preform layoutvoidsetUIManager(UIManager uiManager) Allows replacing the UIManager in a component hierarchy to update the look and feel only to a specific hierarchyintupdateTabIndices(int offset) Updates the tab indices in this container recursively.Methods inherited from class Component
addDragFinishedListener, addDragOverListener, addDropListener, addFocusListener, addLongPressListener, addPointerDraggedListener, addPointerPressedListener, addPointerReleasedListener, addPullToRefresh, addScrollListener, addStateChangeListener, animate, announceForAccessibility, bindProperty, blocksSideSwipe, calcScrollSize, contains, containsOrOwns, createStyleAnimation, deinitializeCustomStyle, dragEnter, dragExit, dragFinished, draggingOver, drawDraggedImage, focusGained, focusLost, getAbsoluteX, getAbsoluteY, getAccessibilityText, getAllStyles, getAnimationManager, getBaseline, getBaselineResizeBehavior, getBindablePropertyNames, getBindablePropertyTypes, getBorder, getBoundPropertyValue, getBounds, getBounds, getClientProperty, getCloudBoundProperty, getCloudDestinationProperty, getComponentForm, getComponentState, getCursor, getDefaultDragTransparency, getDirtyRegion, getDisabledStyle, getDraggedx, getDraggedy, getDragImage, getDragRegionStatus, getDragSpeed, getDragTransparency, getEditingDelegate, getHeight, getInlineAllStyles, getInlineDisabledStyles, getInlinePressedStyles, getInlineSelectedStyles, getInlineStylesTheme, getInlineUnselectedStyles, getInnerHeight, getInnerPreferredH, getInnerPreferredW, getInnerWidth, getInnerX, getInnerY, getLabelForComponent, getName, getNativeOverlay, getNextFocusDown, getNextFocusLeft, getNextFocusRight, getNextFocusUp, getOuterHeight, getOuterPreferredH, getOuterPreferredW, getOuterWidth, getOuterX, getOuterY, getOwner, getParent, getPreferredH, getPreferredSize, getPreferredSizeStr, getPreferredTabIndex, getPreferredW, getPressedStyle, getPropertyNames, getPropertyTypeNames, getPropertyTypes, getPropertyValue, getSameHeight, getSameWidth, getScrollable, getScrollAnimationSpeed, getScrollDimension, getScrollOpacity, getScrollOpacityChangeSpeed, getScrollX, getScrollY, getSelectCommandText, getSelectedRect, getSelectedStyle, getStyle, getTabIndex, getTensileLength, getTextSelectionSupport, getTooltip, getUIID, getUnselectedStyle, getVisibleBounds, getVisibleBounds, getWidth, getX, getY, growShrink, handlesInput, hasFixedPreferredSize, hasFocus, hideNativeOverlay, initComponent, initCustomStyle, initDisabledStyle, initPressedStyle, initSelectedStyle, initUnselectedStyle, installDefaultPainter, isAlwaysTensile, isBlockLead, isCellRenderer, isChildOf, isDragActivated, isDragAndDropOperation, isDraggable, isDragRegion, isDropTarget, isEditable, isEditing, isFlatten, isFocusable, isGrabsPointerEvents, isHidden, isHidden, isHideInLandscape, isHideInPortrait, isIgnorePointerEvents, isInClippingRegion, isInitialized, isOpaque, isOwnedBy, isPinchBlocksDragAndDrop, isRippleEffect, isRTL, isScrollable, isScrollVisible, isSetCursorSupported, isSmoothScrolling, isSnapToGrid, isStickyDrag, isTactileTouch, isTactileTouch, isTensileDragEnabled, isTraversable, isVisible, keyRepeated, laidOut, longKeyPress, longPointerPress, onScrollX, onScrollY, onSetFocusable, paintBackground, paintBackgrounds, paintBorder, paintBorderBackground, paintComponent, paintComponent, paintIntersectingComponentsAbove, paintLock, paintLockRelease, paintRippleOverlay, paintScrollbars, paintScrollbarX, paintScrollbarY, paintShadows, parsePreferredSize, pinch, pinch, pinchReleased, pointerDragged, pointerDragged, pointerHover, pointerHoverPressed, pointerHoverReleased, pointerPressed, pointerReleased, pointerReleased, refreshTheme, refreshTheme, remove, removeDragFinishedListener, removeDragOverListener, removeDropListener, removeFocusListener, removeLongPressListener, removePointerDraggedListener, removePointerPressedListener, removePointerReleasedListener, removeScrollListener, removeStateChangeListener, repaint, repaint, requestFocus, resetFocusable, respondsToPointerEvents, scrollRectToVisible, scrollRectToVisible, setAccessibilityText, setAlwaysTensile, setBlockLead, setBoundPropertyValue, setCloudBoundProperty, setCloudDestinationProperty, setComponentState, setCursor, setDefaultDragTransparency, setDirtyRegion, setDisabledStyle, setDraggable, setDragTransparency, setDropTarget, setEditingDelegate, setFlatten, setFocus, setFocusable, setGrabsPointerEvents, setHandlesInput, setHeight, setHidden, setHidden, setHideInLandscape, setHideInPortrait, setIgnorePointerEvents, setInitialized, setInlineAllStyles, setInlineDisabledStyles, setInlinePressedStyles, setInlineSelectedStyles, setInlineStylesTheme, setInlineUnselectedStyles, setIsScrollVisible, setLabelForComponent, setName, setNextFocusDown, setNextFocusLeft, setNextFocusRight, setNextFocusUp, setOpaque, setOwner, setPinchBlocksDragAndDrop, setPreferredH, setPreferredSize, setPreferredSizeStr, setPreferredTabIndex, setPreferredW, setPressedStyle, setPropertyValue, setRippleEffect, setRTL, setSameHeight, setSameSize, setSameWidth, setScrollAnimationSpeed, setScrollOpacityChangeSpeed, setScrollSize, setScrollVisible, setScrollX, setScrollY, setSelectCommandText, setSelectedStyle, setSize, setSmoothScrolling, setSnapToGrid, setTabIndex, setTactileTouch, setTensileDragEnabled, setTensileLength, setTooltip, setTraversable, setUIID, setUIID, setUIIDFinal, setUnselectedStyle, setVisible, setWidth, setX, setY, shouldBlockSideSwipe, shouldBlockSideSwipeLeft, shouldBlockSideSwipeRight, shouldRenderComponentSelection, showNativeOverlay, startEditingAsync, stopEditing, stripMarginAndPadding, styleChanged, toImage, toString, unbindProperty, updateNativeOverlay, visibleBoundsContainsModifier and TypeMethodDescriptionvoidAdds a listener to the dragFinished eventvoidBroadcasts an event when dragging over a componentvoidBinds an action listener to drop events which are invoked when this component is dropped on a targetvoidRegisters interest in receiving callbacks for focus gained events, a focus event is invoked when the component accepts the focus.voidAdds a listener to the pointer eventvoidAdds a listener to the pointer eventvoidAdds a listener to the pointer eventvoidAdds a listener to the pointer eventvoidaddPullToRefresh(Runnable task) This method adds a refresh task to the Component, the task will be executed if the user has pulled the scroll beyond a certain height.voidRegisters interest in receiving callbacks for scroll gained events, a scroll event is invoked when the component is scrolled.voidAdds a listener to be notified when the state of this component is changed to and from initialized.booleananimate()Allows the animation to reduce "repaint" calls when it returns false.voidManually announces text to native accessibility services, associating the announcement with this component when possible.voidbindProperty(String prop, BindTarget target) Binds the given property name to the given bind targetfinal booleanA component that might need side swipe such as the slider could block it from being used for some other purpose when on top of said component.protected DimensionMethod that can be overriden to represent the actual size of the component when it differs from the desireable size for the viewportbooleancontains(int x, int y) Returns true if the given absolute coordinate is contained in the ComponentbooleancontainsOrOwns(int x, int y) Checks to see if this component either contains the given point, or if it owns the component that contains the given point.createStyleAnimation(String destUIID, int duration) Creates an animation that will transform the current component to the styling of the destination UIID when completed.protected voidAllows components to create a style of their own, this method cleans up state for the given styleprotected voidThis callback method indicates that a component drag has just entered this componentprotected voidThis callback method provides an indication for a drop target that a drag operation is exiting the bounds of this component and it should clear all relevant state if such state exists.protected voiddragFinished(int x, int y) Callback indicating that the drag has finished either via drop or by releasing the componentprotected booleandraggingOver(Component dragged, int x, int y) This method allows a component to indicate if it is a drop target for the given component at the given x/y location (in component coordiate space).protected voiddrawDraggedImage(Graphics g, Image img, int x, int y) Draws the given image at x/y, this method can be overriden to draw additional information such as positive or negative drop indicationprotected voidCallback allowing a developer to track when the component gains focusprotected voidCallback allowing a developer to track wheh the component loses focusintReturns the absolute X location based on the component hierarchy, this method calculates a location on the screen for the component rather than a relative location as returned by getX()intReturns the absolute Y location based on the component hierarchy, this method calculates a location on the screen for the component rather than a relative location as returned by getX()Returns the text that describes this component to assistive technologies.final StyleReturns a "meta style" that allows setting styles once to all the different Style objects, the getters for this style will be meaningless and will return 0 values.Returns the animation manager of the parent form or null if this component isn't currently associated with a formintgetBaseline(int width, int height) The baseline for the component text according to which it should be aligned with other components for best visual look.intReturns a constant indicating how the baseline varies with the size of the component.String[]Returns the names of the properties within this component that can be bound for persistence, the order of these names mean that the first one will be the first boundClass[]Returns the types of the properties that are bindable within this componentprotected BorderNormally returns getStyle().getBorder() but some subclasses might use this to programmatically replace the border in runtime e.g.getBoundPropertyValue(String prop) Allows the binding code to extract the value of the propertyprotected RectangleReturns the component bounds which is sometimes more convenient than invoking getX/Y/Width/Height.Returns the bounds of this component in the provided Rectangle.getClientProperty(String key) Client properties allow the association of meta-data with a component, this is useful for some applications that construct GUI's on the fly and need to track the connection between the UI and the data.Indicates the property within this component that should be bound to the cloud objectThe destination property of the CloudObjectReturns the Component Form or null if this Component is not added yet to a formSome components may optionally generate a state which can then be restored using setCompnentState().intGets the custom cursor for this component.static byteReturns the default translucency used in the#getDragImage()method.final Rectanglegets the Component dirty region, this method is for internal use only and SHOULD NOT be invoked by user code.Returns the Component Style for the disabled state allowing us to manipulate the look of the component when its disabledintGets the current dragged x values when the Component is being draggedintGets the current dragged y values when the Component is being draggedprotected ImageThis method returns an image representing the dragged component, it can be overriden by subclasses to customize the look of the image, the image will be overlaid on top of the form during a drag and drop operationprotected intgetDragRegionStatus(int x, int y) Indicates if the section within the X/Y area is a "drag region" where we expect people to drag or press in which case we can instantly start dragging making perceived performance faster.protected floatgetDragSpeed(boolean vertical) This method returns the dragging speed based on the latest dragged eventsbyteReturns the translucency used in the#getDragImage()method.Gets the delegate that handles the editing of this component.intReturns the component heightGets inline styles that are to be applied to all states of this component.Gets inline styles that are to be applied to the disabled state of this component.Gets inline styles that are to be applied to the pressed state of this component.Gets inline styles that are to be applied to the selected state of this component.Gets the theme that is used by inline styles to reference images.Gets inline styles that are to be applied to the unselected state of this component.intGets the inner height of this component.intGets the preferred height removing vertical padding.intGets the preferred width removing horizontal padding.intGets the inner width of this component.intGets x-coordinate of the inner bounds of this component.intGets the inner y-coordinate of the inner bounds of this component.Allows us to indicate the label associated with this component thus providing visual feedback related for this component e.g.getName()A component name allows us to easily identify the component within a dynamic UI.Gets the native overlay for this component.Allows us to determine which component will receive focus next when traversing with the down keyAllows us to determine which component will receive focus next when traversing with the left key.Allows us to determine which component will receive focus next when traversing with the right keyAllows us to determine which component will receive focus next when traversing with the up key.intGets the outer height of this component.intGets the preferred height including the vertical margins.intGets the preferred width including horizontal margins.intGets the outer width of this component.intGets the x-coordinate of the outer bounds of this component.intGets the Y-coordinate of the outer bounds of this component.getOwner()Gets the "owner" of this component as set by#setOwner(com.codename1.ui.Component).Returns the container in which this component is containedintHelper method to retrieve the preferred height of the component.Returns the Component Preferred Size, there is no guarantee the Component will be sized at its Preferred Size.Returns the preferred size string that can be used to specify the preferred size of the component using pixels or millimetres.intGets the preferred tab index of this component.intHelper method to retrieve the preferred width of the component.Returns the Component Style for the pressed state allowing us to manipulate the look of the component when it is pressedString[]A component may expose mutable property names for a UI designer to manipulate, this API is designed for usage internally by the GUI builder codeString[]This method is here to workaround an XMLVM array type bug where property types aren't identified properly, it returns the names of the types using the following type names: String,int,double,long,byte,short,char,String[],String[][],byte[],Image,Image[],Object[],ListModel,ListCellRendererClass[]Matches the property names method (see that method for further details).getPropertyValue(String name) Returns the current value of the property name, this method is used by the GUI builderReturns the array of components that have an equal heightReturns the array of components that have an equal widthReturns the scrollable parent of this componentintScroll animation speed in milliseconds allowing a developer to slow down or accelerate the smooth animation modeReturns the Components dimension in scrolling, this is very similar to the preferred size aspect only it represents actual scrolling limits.intThis method is used internally by the look and feel to implement the fading scrollbar behavior.intIndicates the decrement units for the scroll opacityintIndicates the X position of the scrolling, this number is relative to the component position and so a position of 0 would indicate the x position of the component.intIndicates the Y position of the scrolling, this number is relative to the component position and so a position of 0 would indicate the y position of the component.Allows determining the text for the select command used in the 3rd softbutton mode.Returns the component bounds with absolute screen coordinates, for components that include an internal selection behavior and are not containers (currently only List) this method allows returning the position of the selection itself which is useful for things such as the popup dialog and similar UI's that need to reference the position of the selection externallyReturns the Component Style for the selected state allowing us to manipulate the look of the component when it owns focusgetStyle()Returns the current Component Style allowing code to draw the current component, you should normally use getUnselected/Pressed/DisabledStyle() and not this method since it will return different values based on component state.intGets the tab index of the component.intRecommended length for the tensile, -1 for defaultReturns text selection support object for this component.Returns
final StringgetUIID()Unique identifier for a component.final StyleReturns the Component Style for the unselected mode allowing us to manipulate the look of the componentprotected RectangleReturns the component bounds for scrolling which might differ from the getBounds for large components e.g.getVisibleBounds(Rectangle rect) Returns the component bounds for scrolling which might differ from the getBounds for large components into the provided rectangle.intgetWidth()Returns the component widthintgetX()Returns the current component x location relatively to its parent containerintgetY()Returns the component y location relatively to its parent containervoidgrowShrink(int duration) Grows or shrinks this component to its new preferred size, this method essentially takes a component whose preferred size has changed and creates a "growing" effect that lasts for the duration.booleanPrevents key events from being grabbed for focus traversal.booleanChecks if this component has a fixed preferred size either via an explicit call to#setPreferredH(int)and#setPreferredW(int), or via a preferred size style string.booleanhasFocus()Returns true if the component has focusprotected voidHides the native overlay for this component.protected voidAllows subclasses to bind functionality that relies on fully initialized and "ready for action" component stateprotected voidAllows components to create a style of their own, this method binds the listener to the style and installs a bg painterprotected voidinitDisabledStyle(Style disabledStyle) Can be overridden by subclasses to perform initialization when the disabled style is set to a new value.protected voidinitPressedStyle(Style pressedStyle) Can be overridden by subclasses to perform initialization when the pressed style is set to a new value.protected voidinitSelectedStyle(Style selectedStyle) Can be overridden by subclasses to perform initialization when the selected style is set to a new value.protected voidinitUnselectedStyle(Style unselectedStyle) Can be overridden by subclasses to perform initialization when the unselected style is set to a new value.protected voidAllows subclasses to create their own custom style types and install the background painter into thembooleanEnable the tensile drag to work even when a component doesn't have a scroll showable (scrollable flag still needs to be set to true)booleanPrevent a lead component hierarchy from this specific component, this allows a component within that hierarchy to still act as a standalone componentbooleanUsed as an optimization to mark that this component is currently being used as a cell rendererbooleanSearches the hierarchy of the component recursively to see if the given Container is one of the parents of this componentprotected booleanIndicates whether we are in the middle of a drag operation, this method allows developers overriding the pointer released events to know when this is a drag operation.protected booleanisDragAndDropOperation(int x, int y) This method allows a developer to define only a specific portion of a component as draggable by default it returns true if the component is defined as "draggable"booleanIndicates whether this component can be dragged in a drag and drop operation rather than scroll the parentprotected booleanisDragRegion(int x, int y) Indicates if the section within the X/Y area is a "drag region" where we expect people to drag and never actually "press" in which case we can instantly start dragging making perceived performance faster.booleanIndicates whether this component can receive dropped components into it, notice that when dropping on a component or container the parents will be checked recursively to find a valid drop targetbooleanChecks to see if the component is editable.booleanChecks if the component is currently being edited.booleanMakes the component effectively opaque by blending the backgrounds into an image in memory so the layer of underlying components is only drawn once when this component is repainted.booleanReturns true if this component can receive focus and is enabledbooleanThis property is useful for blocking in z-order touch events, sometimes we might want to grab touch events in a specific component without making it focusable.booleanisHidden()Returns true if the component was explicitly hidden by the user.booleanisHidden(boolean checkParent) Checks if the component is hidden.booleanIndicates that this component and all its children should be hidden when the device is switched to landscape modebooleanIndicates that this component and all its children should be hidden when the device is switched to portrait modebooleanReturns
protected booleanprotected booleanIndicates if the component is in the initialized state, a component is initialized when its initComponent() method was invoked.booleanisOpaque()Checks whether the component's background should be painted.booleanChecks to see if this component is owned by the given other component.booleanreturns true if pinch will block drag and dropbooleanIndicates whether the component displays the material design ripple effectfinal booleanisRTL()Is the component a bidi RTL componentprotected booleanIndicates whether the component should/could scroll by default a component is not scrollable.booleanIndicate whether this component scroll is visiblestatic booleanChecks to see if this platform supports cursors.booleanIndicates that scrolling through the component should work as an animationbooleanIndicates whether scrolling this component should jump to a specific location in a gridprotected booleanReturns true if the component is interested in receiving drag/pointer release events even after the gesture exceeded its boundaries.booleanIndicates whether the component should "trigger" tactile touch when pressed by the user in a touch screen UI.protected booleanisTactileTouch(int x, int y) Elaborate components might not provide tactile feedback for all their areas (e.g. Lists) this method defaults to returning the value of isTactileTouchbooleanIndicates whether tensile drag (dragging beyond the boundry of the component and snapping back) is enabled for this component.final booleanChecks if this component should be traversable using the keyboard using tab, next, previous keys.booleanReturns whether the component is visible or notvoidkeyRepeated(int keyCode) If this Component is focused, the key repeat event will call this method.protected voidlaidOut()This is a callback method to inform the Component when it's been laidout on the parent Containerprotected voidlongKeyPress(int keyCode) If this Component is focused this method is invoked when the user presses and holds the keyvoidlongPointerPress(int x, int y) If this Component is focused this method is invoked when the user presses and holds the pointer on the Componentprotected voidonScrollX(int scrollX) This method can be overriden to receive scroll events, unlike overriding setScrollX it will receive all calls for scrolling.protected voidonScrollY(int scrollY) This method can be overriden to receive scroll events, unlike overriding setScrollY it will receive all calls for scrolling.protected voidonSetFocusable(boolean focusable) Since setFocusable is final this callback is invoked when focusable changes.protected voidThis method paints the Component background, it should be overriden by subclasses to perform custom background drawing.voidThis method paints all the parents Components Background.protected voidDraws the component border if such a border exists.protected voidDraws the component border background if such a border exists.final voidPaints this component as a root by going to all the parent components and setting the absolute translation based on coordinates and scroll status.final voidpaintComponent(Graphics g, boolean background) Paints this component as a root by going to all the parent components and setting the absolute translation based on coordinates and scroll status.voidPaints intersecting components that appear above this component.paintLock(boolean hardLock) This method locks the component so it will always paint the given image instead of running through its paint logic.voidReleases the paint lock image to allow paint to work as usual, see paintLock(boolean) for detailsvoidpaintRippleOverlay(Graphics g, int x, int y, int position) Invoked to draw the ripple effect overlay in Android where the finger of the user causes a growing circular overlay over time.protected voidPaints the UI for the scrollbars on the component, this will be invoked only for scrollable components.protected voidPaints the UI for the scrollbar on the X axis, this method allows component subclasses to customize the look of a scrollbarprotected voidPaints the UI for the scrollbar on the Y axis, this method allows component subclasses to customize the look of a scrollbarvoidpaintShadows(Graphics g, int relativeX, int relativeY) Paints the drop-shadow projections for this component based on its elevation value.static DimensionparsePreferredSize(String preferredSize, Dimension baseSize) Parses the preferred size given as a stringprotected booleanpinch(float scale) Invoked by subclasses interested in handling pinch to zoom events, if true is returned other drag events will not be broadcastprotected booleanpinch(int[] x, int[] y) Invoked by subclasses interested in handling pinch to do their own actions based on the position of the two fingers, if true is returned other drag events will not be broadcastprotected voidpinchReleased(int x, int y) To be implemented by subclasses interested in being notified when a pinch zoom has ended (i.e the user has removed one of their fingers, but is still dragging).voidpointerDragged(int[] x, int[] y) If this Component is focused, the pointer dragged event will call this methodvoidpointerDragged(int x, int y) If this Component is focused, the pointer dragged event will call this methodvoidpointerHover(int[] x, int[] y) Invoked for devices where the pointer can hover without actually clicking the display.voidpointerHoverPressed(int[] x, int[] y) Invoked for devices where the pointer can hover without actually clicking the display.voidpointerHoverReleased(int[] x, int[] y) Invoked for devices where the pointer can hover without actually clicking the display.voidpointerPressed(int[] x, int[] y) If this Component is focused, the pointer pressed event will call this methodvoidpointerReleased(int[] x, int[] y) If this Component is focused, the pointer released event will call this methodvoidpointerReleased(int x, int y) If this Component is focused, the pointer released event will call this methodvoidMakes sure the component is up to date with the current theme, ONLY INVOKE THIS METHOD IF YOU CHANGED THE THEME!protected voidrefreshTheme(String id, boolean merge) Makes sure the component is up to date with the given UIIDvoidremove()This method will remove the Component from its parent.voidRemoves the listener from the drag finished eventvoidRemoves an action listener to drag over eventsvoidRemoves an action listener to drop events which are invoked when this component is dropped on a targetvoidDeregisters interest in receiving callbacks for focus gained eventsvoidRemoves the listener from the pointer eventvoidRemoves the listener from the pointer eventvoidRemoves the listener from the pointer eventvoidRemoves the listener from the pointer eventvoidDeregisters interest in receiving callbacks for scroll gained eventsvoidRemoves a listener from being notified when the state of this component is changed to and from initialized.voidrepaint()Repaint this Component, the repaint call causes a callback of the paint method on the event dispatch thread.voidrepaint(int x, int y, int w, int h) Repaints a specific region within the componentvoidChanges the current component to the focused component, will work only for a component that belongs to a parent form.protected voidRestores the state of the focusable flag to its default statebooleanChecks if the component responds to pointer events.voidscrollRectToVisible(int x, int y, int width, int height, Component coordinateSpace) Makes sure the component is visible in the scroll if this container is scrollableprotected voidscrollRectToVisible(Rectangle rect, Component coordinateSpace) Makes sure the component is visible in the scroll if this container is scrollablevoidsetAccessibilityText(String text) Sets the text that describes this component to assistive technologies.voidsetAlwaysTensile(boolean alwaysTensile) Enable the tensile drag to work even when a component doesn't have a scroll showable (scrollable flag still needs to be set to true)voidsetBlockLead(boolean blockLead) Prevent a lead component hierarchy from this specific component, this allows a component within that hierarchy to still act as a standalone componentvoidsetBoundPropertyValue(String prop, Object value) Sets the value of a bound property within this component, notice that this method MUST NOT fire the property change event when invoked to prevent recursion!voidsetCloudBoundProperty(String cloudBoundProperty) Indicates the property within this component that should be bound to the cloud objectvoidsetCloudDestinationProperty(String cloudDestinationProperty) The destination property of the CloudObjectvoidsetComponentState(Object state) If getComponentState returned a value the setter can update the value and restore the prior state.voidsetCursor(int cursor) Sets a custom mouse cursor for this component if the platform supports mouse cursors, notice that this isn't applicable for touch devices.static voidsetDefaultDragTransparency(byte defaultDragTransparency) Sets the default translucency of the#getDragImage()method.final voidsetDirtyRegion(Rectangle dirty) sets the Component dirty region, this method is for internal use only and SHOULD NOT be invoked by user code.voidsetDisabledStyle(Style style) Changes the Component disalbed Style by replacing the Component Style with the given StylevoidsetDraggable(boolean draggable) Indicates whether this component can be dragged in a drag and drop operation rather than scroll the parentvoidsetDragTransparency(byte dragTransparency) Sets the translucency of the#getDragImage()method.voidsetDropTarget(boolean dropTarget) Indicates whether this component can receive dropped components into it, notice that when dropping on a component or container the parents will be checked recursively to find a valid drop targetvoidsetEditingDelegate(Editable editable) Sets the editing delegate for this component.voidsetFlatten(boolean flatten) Makes the component effectively opaque by blending the backgrounds into an image in memory so the layer of underlying components is only drawn once when this component is repainted.voidsetFocus(boolean focused) This flag doesn't really give focus, its a state that determines what colors from the Style should be used when painting the component.final voidsetFocusable(boolean focusable) A simple setter to determine if this Component can get focusedvoidsetGrabsPointerEvents(boolean grabsPointerEvents) This property is useful for blocking in z-order touch events, sometimes we might want to grab touch events in a specific component without making it focusable.voidsetHandlesInput(boolean handlesInput) Prevents key events from being grabbed for focus traversal.voidsetHeight(int height) Sets the Component height, this method is exposed for the purpose of external layout managers and should not be invoked directly.voidsetHidden(boolean b) Makes the components preferred size equal 0 when hidden and restores it to the default size when not.voidsetHidden(boolean b, boolean changeMargin) Makes the components preferred size equal 0 when hidden and restores it to the default size when not.voidsetHideInLandscape(boolean hideInLandscape) Indicates that this component and all its children should be hidden when the device is switched to landscape modevoidsetHideInPortrait(boolean hideInPortrait) Indicates that this component and all its children should be hidden when the device is switched to portrait modevoidsetIgnorePointerEvents(boolean ignorePointerEvents) Parameters
protected voidsetInitialized(boolean initialized) Indicates if the component is in the initialized state, a component is initialized when its initComponent() method was invoked.voidsetInlineAllStyles(String styles) Registers inline styles that should be applied to all states of the component.voidsetInlineDisabledStyles(String styles) Registers inline styles that should be applied to the disabled state of the component.voidsetInlinePressedStyles(String styles) Registers inline styles that should be applied to the pressed state of the component.voidsetInlineSelectedStyles(String styles) Registers inline styles that should be applied to the selected state of the component.voidsetInlineStylesTheme(Resources inlineStylesTheme) Sets the theme that is used by inline styles to reference images.voidsetInlineUnselectedStyles(String styles) Registers inline styles that should be applied to the unselected state of the component.voidsetIsScrollVisible(boolean isScrollVisible) Set whether this component scroll is visiblevoidsetLabelForComponent(Label componentLabel) Allows us to indicate the label associated with this component thus providing visual feedback related for this component e.g.voidA component name allows us to easily identify the component within a dynamic UI.voidsetNextFocusDown(Component nextFocusDown) Allows us to determine which component will receive focus next when traversing with the down keyvoidsetNextFocusLeft(Component nextFocusLeft) Allows us to determine which component will receive focus next when traversing with the left key, this method doesn't affect the general focus behavior.voidsetNextFocusRight(Component nextFocusRight) Allows us to determine which component will receive focus next when traversing with the right keyvoidsetNextFocusUp(Component nextFocusUp) Allows us to determine which component will receive focus next when traversing with the up key, this method doesn't affect the general focus behavior.final voidsetOpaque(boolean opaque) Sets whether or not to paint the component background.voidSets the owner of this component to the specified component.voidsetPinchBlocksDragAndDrop(boolean block) If a component supports pinch as well as drag and drop the two may conflict (if one finger is placed a bit before the other, the drag timer will be initiated and may trigger drag even if the second finger has been placed before).voidsetPreferredH(int preferredH) Helper method to set the preferred height of the component.voidSets the Component Preferred Size, there is no guarantee the Component will be sized at its Preferred Size.voidsetPreferredSizeStr(String value) Parameters
voidsetPreferredTabIndex(int index) Sets the preferred tab index of the component.voidsetPreferredW(int preferredW) Helper method to set the preferred width of the component.voidsetPressedStyle(Style style) Sets the Component Style for the pressed state allowing us to manipulate the look of the component when it is pressedsetPropertyValue(String name, Object value) Sets a new value to the given property, returns an error message if failed and null if successful.voidsetRippleEffect(boolean rippleEffect) Indicates whether the component displays the material design ripple effectvoidsetRTL(boolean rtl) Is the component a bidi RTL componentstatic voidsetSameHeight(Component... c) Places all of these components in the same height group, to remove a component from the group invoke this method with that component only.static voidsetSameSize(Component... c) This is identical to invoking#sameWidthfollowed by#sameHeightstatic voidsetSameWidth(Component... c) Places all of these components in the same width group, to remove a component from the group invoke this method with that component only.voidsetScrollAnimationSpeed(int animationSpeed) Scroll animation speed in milliseconds allowing a developer to slow down or accelerate the smooth animation modevoidsetScrollOpacityChangeSpeed(int scrollOpacityChangeSpeed) Indicates the decrement units for the scroll opacityvoidSet the size for the scroll areavoidsetScrollVisible(boolean isScrollVisible) Set whether this component scroll is visibleprotected voidsetScrollX(int scrollX) Indicates the X position of the scrolling, this number is relative to the component position and so a position of 0 would indicate the x position of the component.protected voidsetScrollY(int scrollY) Indicates the Y position of the scrolling, this number is relative to the component position and so a position of 0 would indicate the y position of the component.voidsetSelectCommandText(String selectText) Allows determining the text for the select command used in the 3rd softbutton mode.voidsetSelectedStyle(Style style) Changes the Component selected Style by replacing the Component Style with the given StylevoidSets the Component size, this method is exposed for the purpose of external layout managers and should not be invoked directly.voidsetSmoothScrolling(boolean smoothScrolling) Indicates that scrolling through the component should work as an animationvoidsetSnapToGrid(boolean snapToGrid) Indicates whether scrolling this component should jump to a specific location in a gridvoidsetTabIndex(int index) Sets the tab index of the component.voidsetTactileTouch(boolean tactileTouch) Indicates whether the component should "trigger" tactile touch when pressed by the user in a touch screen UI.voidsetTensileDragEnabled(boolean tensileDragEnabled) Indicates whether tensile drag (dragging beyond the boundry of the component and snapping back) is enabled for this component.voidsetTensileLength(int tensileLength) Recommended length for the tensile, -1 for defaultvoidsetTooltip(String tooltip) Parameters
final voidsetTraversable(boolean traversable) Sets whether this component is traversable using the keyboard using tab, next, previous keys.voidThis method sets the Component the Unique identifier.voidThis method sets the Component the Unique identifier.protected final voidsetUIIDFinal(String id) This method is the implementation of setUIID and is defined as final to allow invocation from constructors.voidsetUnselectedStyle(Style style) Changes the Component Style by replacing the Component Style with the given StylevoidsetVisible(boolean visible) Toggles visibility of the componentvoidsetWidth(int width) Sets the Component width, this method is exposed for the purpose of external layout managers and should not be invoked directly.voidsetX(int x) Sets the Component x location relative to the parent container, this method is exposed for the purpose of external layout managers and should not be invoked directly.voidsetY(int y) Sets the Component y location relative to the parent container, this method is exposed for the purpose of external layout managers and should not be invoked directly.protected booleanA component that might need side swipe such as the slider could block it from being used for some other purpose when on top of said component.protected booleanA component that might need side swipe such as the tabs could block it from being used for some other purpose when on top of said component.protected booleanA component that might need side swipe such as the tabs could block it from being used for some other purpose when on top of said component.protected booleanA component can indicate whether it is interested in rendering it's selection explicitly, this defaults to true in non-touch UI's and false in touch UI's except for the case where a user clicks the screen.protected voidCreates the native overlay for this component.voidIf the component#isEditable(), then this will start the editing process.voidstopEditing(Runnable onFinish) Stops the editing process.Convenience method that strips margin and padding from the component, and returns itself for chaining.voidstyleChanged(String propertyName, Style source) Invoked to indicate a change in a propertyName of a StyletoImage()Returns the component as an image.toString()Overriden to return a useful value for debugging purposesvoidunbindProperty(String prop, BindTarget target) Removes a bind target from the given property nameprotected voidUpdates the native overlay for this component.booleanvisibleBoundsContains(int x, int y) Returns true if the given absolute coordinate is contained inside the visible bounds of the component.Methods inherited from class Object
clone, equals, getClass, hashCode, notify, notifyAll, wait, wait, waitModifier and TypeMethodDescriptionprotected Objectclone()booleanIndicates whether some other object is "equal to" this one.final ClassgetClass()Returns the runtime class of an object.inthashCode()Returns a hash code value for the object.final voidnotify()Wakes up a single thread that is waiting on this object's monitor.final voidWakes up all threads that are waiting on this object's monitor.final voidwait()Causes current thread to wait until another thread invokes the method or the method for this object.final voidwait(long timeout) Causes current thread to wait until either another thread invokes the method or the method for this object, or a specified amount of time has elapsed.final voidwait(long timeout, int nanos) Causes current thread to wait until another thread invokes the method or the method for this object, or some other thread interrupts the current thread, or a certain amount of real time has elapsed.
-
Field Details
-
BROWSER_PROPERTY_FOLLOW_TARGET_BLANK
Browser property key to control whether links withtarget="_blank"ortarget="_new"should be followed in the current browser view. Defaults totrue.- See Also:
-
onStart
String constant for web event listenercom.codename1.ui.events.ActionListener)- See Also:
-
onLoad
String constant for web event listenercom.codename1.ui.events.ActionListener)- See Also:
-
onError
String constant for web event listenercom.codename1.ui.events.ActionListener)- See Also:
-
onMessage
String constant for web event listener. Use this event types to register to receive messages in a cross-domain-safe way from the web page. To send a message from the webpage, the page should include a function like:
`function postToCN1(msg) { if (window.cn1PostMessage) { // Case 1: Running inside native app in a WebView window.cn1PostMessage(msg);` else { // Case 2: Running inside a Javascript app in an iframe window.parent.postMessage(msg, '*'); } } }Receiving a message:
`myBrowserComponent.addWebEventListener(BrowserComponent.onMessage, e->{ CN.callSerially(()->{ Log.p("Message: "+e.getSource()); Dialog.show("Here", (String)e.getSource(), "OK", null);`); }); }- See Also:
-
-
Constructor Details
-
BrowserComponent
public BrowserComponent()This constructor will work as expected when a browser component is supported, see isNativeBrowserSupported()
-
-
Method Details
-
isNativeBrowserSupported
public static boolean isNativeBrowserSupported()Returns true if the platform supports embedding a native browser component
Returns
true if native browsing is supported
-
injectParameters
Injects parameters into a Javascript string expression. This will quote strings properly. The expression should include placeholders for each parameter of the form ${0}, ${1}, etc..
Parameters
-
jsExpression: The javascript expression with placeholders to inject parameters. -
params
Returns
The expression with placeholders replaced by parameters.
-
-
createDataURI
This method creates a data URI which allows developers creating HTML for local use to embed local images into the HTML by appending them as a URI. E.g. instead of referencing a file or URL just load the image data and place the contents of this string into the src attribute.
This is the easiest way to get an HTML with local images to work on all mobile platforms.
Parameters
-
data: data of an image -
mime: the mime type of the image e.g. image/png
Returns
a data URL that can be placed into the img src attribute in HTML e.g. data:image/png;base64,encodedData
Since
6.0
-
-
isFireCallbacksOnEdt
public boolean isFireCallbacksOnEdt()Checks if javascript callbacks are run on the EDT.
Returns
True if javascript callbacks are run on the EDT.
Since
5.0
See also
- #setFireCallbacksOnEdt(boolean)
-
setFireCallbacksOnEdt
public void setFireCallbacksOnEdt(boolean edt) Sets whether javascript callbacks should be run on the EDT. Default is true.
Parameters
edt: True if callbacks should be run on EDT. False if they should be run on the platform's main thread.
Since
5.0
-
captureScreenshot
Async method for capturing a screenshot of the browser content. Currently only supported in the simulator. Also, only displays the visible rectangle of the BrowserComponent, not the entire page.
Returns
AsyncResource resolving to an Image of the webview contents.
Since
7.0
-
deinitialize
protected void deinitialize()Description copied from class:ComponentInvoked to indicate that the component initialization is being reversed since the component was detached from the container hierarchy. This allows the component to deregister animators and cleanup after itself. This method is the opposite of the initComponent() method.- Overrides:
deinitializein classComponent
-
postMessage
Calls the postMessage() method on the webpage's window object.
This is useful mainly for the Javascript port so that you don't have to worry about cross-domain issues, as postMessage() is supported cross-domain.
To receive a message, the web page should register a "message" event listener, just as it would to receive messages from other windows in the browser. See MDN docs for postMessage() for more information.
Parameters
-
message: The message to send. -
targetOrigin: The target origin of the message. E.g. http://example.com:1234
Since
7.0
-
-
waitForReady
public void waitForReady()Uses invokeAndBlock to wait until the BrowserComponent is ready. The browser component is considered to be ready once the onLoad event has been fired for the first page. -
ready
Registers a callback to be run when the BrowserComponent is "ready". The browser component is considered to be ready once the onLoad event has been fired on the first page. If this method is called after the browser component is already "ready", then the callback will be executed immediately. Otherwise it will be called in the first onLoad event.
Parameters
onReady: Callback to be executed when the browser component is ready.
Returns
Self for chaining.
Since
7.0
See also
- #waitForReady()
-
ready
Returns a promise that will complete when the browser component is "ready". It is considered to be ready once it has received the start or load event from at least one page. Default timeout is 5000ms.
Returns
AsyncResouce that will complete when the browser component is ready.
Since
7.0
-
ready
Returns a promise that will complete when the browser component is "ready". It is considered to be ready once it has received the start or load event from at least one page.
Parameters
timeout: Timeout in milliseconds to wait.
Returns
AsyncResouce that will complete when the browser component is ready.
Since
7.0
-
setProperty
This method allows customizing the properties of a web view in various ways including platform specific settings. When a property isn't supported by a specific platform it is just ignored.
Parameters
-
key: see the documentation with the CodenameOne Implementation for further details -
value: see the documentation with the CodenameOne Implementation for further details
-
-
getTitle
The page title
Returns
the title
-
getURL
The page URL
Returns
the URL
-
setURL
Sets the page URL, jar: URL's must be supported by the implementation
Parameters
url: the URL
-
setURL
Sets the page URL.
Parameters
url: The URL to the page to display.
-
setURL
Sets the page URL.
Parameters
uri: URI to the page to display.
-
setURL
-
isURLWithCustomHeadersSupported
public boolean isURLWithCustomHeadersSupported()Returns true if the method
java.util.Map)is supportedReturns
false by default
-
setURLHierarchy
Sets the page URL while respecting the hierarchy of the html
Parameters
url: the URL
- Throws:
IOException
-
reload
public void reload()Reload the current page -
hasBack
public boolean hasBack()Indicates whether back is currently available
Returns
true if back should work
-
hasForward
public boolean hasForward()Indicates whether forward is currently available
Returns
true if forward should work
-
back
public void back()Navigates back in the history -
forward
public void forward()Navigates forward in the history -
clearHistory
public void clearHistory()Clears navigation history -
isPinchToZoomEnabled
public boolean isPinchToZoomEnabled()This method is unreliable and is only here for consistency with setPinchToZoomEnabled, it will not return whether the platform supports pinch since this is very hard to detect properly.
Returns
the last value for setPinchToZoomEnabled
-
setPinchToZoomEnabled
public void setPinchToZoomEnabled(boolean e) Some platforms require that you enable pinch to zoom explicitly. This method has no effect if pinch to zoom isn't supported by the platform
Parameters
e: true to enable pinch to zoom, false to disable it
-
isNativeScrollingEnabled
public boolean isNativeScrollingEnabled()This method is unreliable and is only here for consistency with setNativeScrollingEnabled.
Returns
the last value for setNativeScrollingEnabled
-
setNativeScrollingEnabled
public void setNativeScrollingEnabled(boolean b) This flag allows disabling the native browser scrolling on platforms that support it
Parameters
b: true to enable native scrolling, notice that non-native scrolling might be problematic
-
setPage
-
addWebEventListener
Adds a listener to the given event type name, event type names are platform specific but some must be fired for all platforms and will invoke the action listener when the appropriate event loads
Parameters
-
type: platform specific but must support: onStart, onLoad, onError -
listener: callback for the event
-
-
removeWebEventListener
Removes the listener, see addWebEventListener for details
Parameters
-
type: see addWebEventListener for details -
listener: see addWebEventListener for details
-
-
stop
public void stop()Cancel the loading of the current page -
destroy
public void destroy()Release native resources of this Browser Component -
fireWebEvent
Used internally by the implementation to fire an event from the native browser widget
Parameters
-
type: the type of the event -
ev: the event
-
-
execute
Executes the given JavaScript string within the current context
Parameters
javaScript: the JavaScript string
-
execute
Executes given javascript string within current context.
Parameters
-
js: The javascript to execute. -
params: @param params Parameters to inject into the javascript expression. The expression should contain placeholders of the form ${0 }, ${1 }, etc... to be replaced. Seejava.lang.Object...)for more information about injected parameters. by parameters.
-
-
executeAndReturnString
Executes the given JavaScript and returns a result string from the underlying platform where applicable.
Note: Some platforms use
Display#invokeAndBlock(java.lang.Runnable)inside this method which is very costly. Try to avoid this synchronous method, and prefer to use one of the asynchronous versions. E.g.com.codename1.util.SuccessCallback)Parameters
javaScript: the JavaScript code to execute
Returns
the string returned from the Javascript call
-
executeAndReturnString
Executes the given javascript and returns the result string from the underlying platform.
Note: Some platforms use
Display#invokeAndBlock(java.lang.Runnable)inside this method which is very costly. Try to avoid this synchronous method, and prefer to use one of the asynchronous versions. E.g.com.codename1.util.SuccessCallback)Parameters
-
javaScript: The javascript to execute. -
params: Parameters to inject into the javascript expression. The expression should contain placeholders of the form ${0 }, ${1 }, etc... to be replaced. Seejava.lang.Object...)for more information about injected parameters.
Returns
The result as a string.
Since
5.0
-
-
createJSProxy
Creates a proxy for a Javascript object that makes it easier to call methods, retrieve, and manipulate properties on the object. -
execute
Asynchronously executes the provided javascript expression. The expression may provide a callback which you can call inside the expression directly.
Example
Getting the window object.
`bc.execute("callback.onSuccess(window)", value -> { System.out.println("value="+value+"; type="+value.getJSType()); // value=[object Window]; type=OBJECT`); }Getting an Integer
`bc.execute("callback.onSuccess(1+2)", value -> { System.out.println("value="+value.getInt()+"; type="+value.getJSType()); // value=3; type=NUMBER`); }Getting a String
`bc.execute("callback.onSuccess('hello world')",value -> { System.out.println("value="+value+"; type="+value.getJSType()); // value=hello world; type=STRING` ); }After a Javascript Timeout
Since this call is asynchronous, the javascript code can wait to call the callback to any time in the future - e.g. after a timeout, after an ajax response, in some event handler, etc.. The CN1 UI will not be blocked, the provided callback will be called at the appropriate time on the EDT.
`bc.execute("setTimeout(function(){callback.onSuccess('hello world')`, 1500)", value -> { System.out.println("value="+value+"; type="+value.getJSType()); // value=hello world; type=STRING } ); }NOTE: The callback can only be called once, so you shouldn't use this method to register a callback with an event listener that will be called repeatedly. If you want to register a Java callback with a Javascript event, you should use the
com.codename1.util.Callback)method instead.Parameters
-
js: The javascript expression. If you want to receive any result from this expression, the expression itself must include a call to callback.onSuccess(value). -
callback: The callback. You should call this directly from Javascript. You can call eithercallback.onSuccess(value)orcallback.onError(message,code).
-
-
execute
Execute javascript with a timeout. If timeout is reached before callback is run, then the callback's onError method is run (if callback is a Callback). If callback isn't a Callback (i.e. has no onError(), then this will log an error, and call the onSucess method with a null arg.
Parameters
-
js: The javascript to execute -
timeout: The timeout in milliseconds. -
callback: The callback
-
-
execute
public void execute(int timeout, String js, Object[] params, SuccessCallback<BrowserComponent.JSRef> callback) Executes Javascript expression.
Parameters
-
timeout: The timeout in ms -
js: The javascript expression to execute. -
params: @param params Parameters to inject into the javascript expression. The expression should contain placeholders of the form ${0 }, ${1 }, etc... to be replaced. Seejava.lang.Object...)for more information about injected parameters. by parameters. -
callback: Callback to call when complete.
-
-
execute
Executes Javascript expression.
Parameters
-
js: The javascript expression to execute. -
params: @param params Parameters to inject into the javascript expression. The expression should contain placeholders of the form ${0 }, ${1 }, etc... to be replaced. Seejava.lang.Object...)for more information about injected parameters. by parameters. -
callback: Callback to call when complete.
-
-
addJSCallback
Registers a Java method as a callback in javascript. The callback argument can be referenced inside the javascript expression so that it can be fired when certain events occur.
Examples
Register a Callback to be called whenever a button is clicked
`bc.addJSCallback("someButton.addEventListener('click', function(){callback.onSuccess('hello world')`)", new Callback() { public void onSucess(JSRef value) { System.out.println("Received click: "+value); } }); }Parameters
-
installJs -
callback
-
-
addJSCallback
public void addJSCallback(String installJs, Object[] params, SuccessCallback<BrowserComponent.JSRef> callback) Registers Java method as a callback in Javascript. The callback argument can be referenced inside the javascript expression so that it can be fired when certain events occur.
Parameters
-
installJs: The javascript expression. to run. -
params: @param params Parameters to inject into the javascript expression. The expression should contain placeholders of the form ${0 }, ${1 }, etc... to be replaced. Seejava.lang.Object...)for more information about injected parameters. by parameters. -
callback: The callback to call on completion.
-
-
removeJSCallback
Removes a JS callback that was added via the
com.codename1.util.SuccessCallback)method.Note: This won't unregister any callbacks from the Javascript environment. You'll need to perform your own additional cleanup in Javascript if this callback is registered in any event handlers.
Parameters
callback: The callback to remove.
-
removeJSCallback
-
executeAndWait
This uses invokeAndBlock to wait for the result of the given javascript expression.
Parameters
-
timeout: Timeout in milliseconds. -
js: The javascript expression. -
params: Parameters to inject in the expression. Seejava.lang.Object...)for details.
Returns
The result.
-
-
executeAndWait
This uses invokeAndBlock to wait for the result of the given javascript expression.
Parameters
-
js: The javascript expression. -
params: Parameters to inject in the expression. Seejava.lang.Object...)for details.
Returns
The result.
-
-
executeAndWait
This uses invokeAndBlock to wait for the result of the given javascript expression. It is extremely important that the js expression calls either
callback.onSuccess(value)orliteralcallback.onError(message, code)at some point, or this method will never return.#executeAndWait(java.lang.String)vs#executeAndReturnString(java.lang.String)#executeAndReturnString(java.lang.String)is also blocking, but it uses javascript eval to return the value of the expression. Therefore it can't return the result of any asynchronous operations.#executeAndWait(java.lang.String)is built directly on top ofcom.codename1.util.SuccessCallback)which is fully asynchronous, and allows you to specify where and when you call the callback within the javascript code. This means that you must explicitly call eithercallback.onSuccess(value)orliteralcallback.onError(message, code)at some point in the Javascript expression - or the method will block indefinitely.Parameters
js: The javascript expression to execute. You must callcallback.onSuccess(value)with the result that you want to have returned.
Returns
The result that is returned from javascript when it calls
callback.onSuccess(value) -
executeAndWait
This uses invokeAndBlock to wait for the result of the given javascript expression. It is extremely important that the js expression calls either
callback.onSuccess(value)orliteralcallback.onError(message, code)at some point, or this method will never return.#executeAndWait(java.lang.String)vs#executeAndReturnString(java.lang.String)#executeAndReturnString(java.lang.String)is also blocking, but it uses javascript eval to return the value of the expression. Therefore it can't return the result of any asynchronous operations.#executeAndWait(java.lang.String)is built directly on top ofcom.codename1.util.SuccessCallback)which is fully asynchronous, and allows you to specify where and when you call the callback within the javascript code. This means that you must explicitly call eithercallback.onSuccess(value)orliteralcallback.onError(message, code)at some point in the Javascript expression - or the method will block indefinitely.Parameters
-
timeout: Timeout in ms -
js: The javascript expression to execute. You must callcallback.onSuccess(value)with the result that you want to have returned.
Returns
The result that is returned from javascript when it calls
callback.onSuccess(value) -
-
exposeInJavaScript
Allows exposing the given object to JavaScript code so the JavaScript code can invoke methods and access fields on the given object. Notice that on RIM devices which don't support reflection this object must implement the propriatery Scriptable interface http://www.blackberry.com/developers/docs/5.0.0api/net/rim/device/api/script/Scriptable.html
Parameters
-
o: the object to invoke, notice all public fields and methods would be exposed to JavaScript -
name: the name to expose within JavaScript
Deprecated
-
-
putClientProperty
Sets a client property on this component. BrowserComponent supports several special client properties that control platform-specific behavior.
HTML5/JavaScript Port Client Properties
-
HTML5Peer.removeOnDeinitialize(Boolean): Controls whether the underlying iframe is removed from the DOM when the component is deinitialized.When a Dialog is shown, the parent Form is deinitialized, which normally causes BrowserComponent's iframe to be removed from the DOM. When the Dialog is dismissed, the Form is re-shown but the iframe must be recreated from scratch, losing all JavaScript state (Monaco editor content, event listeners, etc.).
Setting this to
Boolean.FALSEpreserves the iframe in the DOM across deinitialization cycles, which is essential for:- WebRTC connections that break when removed from DOM
- Editors and interactive components that need to preserve state
- Any app that shows dialogs over a BrowserComponent
Example:
BrowserComponent browser = new BrowserComponent(); browser.putClientProperty("HTML5Peer.removeOnDeinitialize", Boolean.FALSE); -
BrowserComponent.firebug(Boolean): Enables debug mode with Firebug console integration (development only).
- Overrides:
putClientPropertyin classComponent- Parameters:
key- the client property keyvalue- the client property value
-
-
isDebugMode
public boolean isDebugMode()Indicates if debug mode is set (might have no effect though)
Returns
true if debug mode was activated
-
setDebugMode
public void setDebugMode(boolean mode) Toggles debug mode for the browser component which helps detect coding errors in the JavaScript bridge logic
Parameters
mode: true to debug false otherwise, this might have no effect in some platforms
-