private static String boundsToString(Bounds bounds) { Point upperLeftCorner = bounds.getUpperLeftCorner(); Point bottomRightCorner = bounds.getLowerRightCorner(); return pointToString(upperLeftCorner).concat(pointToString(bottomRightCorner)); }
public String constructAttributeSelector(CssAttribute attribute, Object propertyValue) { String propertyStringValue; if (propertyValue instanceof Bounds) { Bounds bounds = (Bounds) propertyValue; Point firstBound = bounds.getUpperLeftCorner(); Point secondBound = bounds.getLowerRightCorner(); propertyStringValue = String.format(BOUNDS_FORMAT, firstBound.getX(), firstBound.getY(), secondBound.getX(), secondBound.getY()); } else { propertyStringValue = propertyValue.toString(); } return String.format(queryString, attribute.getHtmlAttributeName(), propertyStringValue); } }
/** * Gets the given bounds equivalent relative to the bounds upper left corner; * * @param bounds * - {@link Bounds} for which to get the relative bounds to the bounds upper left corner * @return the bounds equivalent relative to the bounds upper left corner */ public Bounds getRelativeBounds(Bounds bounds) { Point boundsUpperLeftCorner = bounds.getUpperLeftCorner(); int boundsWidth = bounds.getWidth(); int boundsHeight = bounds.getHeight(); Point relativeUpperLeftCorner = getRelativePoint(boundsUpperLeftCorner); Bounds relativeBounds = new Bounds(relativeUpperLeftCorner, boundsWidth, boundsHeight); return relativeBounds; }
/** * Simulates a pinch out on the element. NOTE emulator devices may not detect pinch gestures on UI elements with * size smaller than 100x100dp. * * @return <code>true</code> if the pinch out is successful, <code>false</code> if it fails * @throws StaleElementReferenceException * if the element has become stale before executing this method */ public boolean pinchOut() { revalidateThrowing(); Bounds elementBounds = propertiesContainer.getBounds(); Point firstFingerEnd = elementBounds.getUpperLeftCorner(); Point secondFingerEnd = elementBounds.getLowerRightCorner(); boolean result = (boolean) communicator.sendAction(RoutingAction.GESTURE_PINCH_OUT, firstFingerEnd, secondFingerEnd); return result; }
/** * Simulates tapping on a relative point in the current UI element. * * @param point * - the relative point that will be added to the upper left corner's coordinates * @return <code>true</code> if the tapping is successful, <code>false</code> if it fails * @throws StaleElementReferenceException * if the element has become stale before executing this method */ public boolean tap(Point point) { revalidateThrowing(); Bounds elementBounds = propertiesContainer.getBounds(); Point tapPoint = elementBounds.getUpperLeftCorner(); tapPoint.addVector(point); if (elementBounds.contains(tapPoint)) { boolean isElementTapped = (boolean) communicator.sendAction(RoutingAction.GESTURE_TAP, tapPoint); finalizeUiElementOperation(); return isElementTapped; } else { String message = String.format("Point %s not in element bounds.", point.toString()); LOGGER.error(message); throw new IllegalArgumentException(message); } }
/** * Simulates double-tapping on a point in this UiElement. * * @param point * - a {@link Point} object, representing the relative coordinates of the point to tap inside this UiElement. * <i><b><u>Note</u></b>: the point with relative coordinates (0,0) denotes the upper-left corner of the * UiElement</i> * @return <code>true</code> if the double tapping is successful, <code>false</code> if it fails * @throws StaleElementReferenceException * if the element has become stale before executing this method */ public boolean doubleTap(Point point) { revalidateThrowing(); Bounds elementBounds = propertiesContainer.getBounds(); Point tapPoint = elementBounds.getUpperLeftCorner(); tapPoint.addVector(point); if (elementBounds.contains(tapPoint)) { boolean isElementTapped = (boolean) communicator.sendAction(RoutingAction.GESTURE_DOUBLE_TAP, tapPoint); finalizeUiElementOperation(); return isElementTapped; } else { String message = String.format("Point %s not in element bounds.", point.toString()); LOGGER.error(message); throw new IllegalArgumentException(message); } }
/** * Simulates long press on given point inside the current {@link UiElement uielement} for given time. * * @param innerPoint * - point, representing the relative coordinates of the point for long press, inside the element's bounds * @param timeout * - time in ms for which the element should be held * @return true, if operation is successful, and false otherwise * @throws StaleElementReferenceException * if the element has become stale before executing this method */ public boolean longPress(Point innerPoint, int timeout) { revalidateThrowing(); Bounds elementBounds = propertiesContainer.getBounds(); Point longPressPoint = elementBounds.getUpperLeftCorner(); longPressPoint.addVector(innerPoint); if (elementBounds.contains(longPressPoint)) { boolean isElementTapped = (boolean) communicator.sendAction(RoutingAction.GESTURE_LONG_PRESS, longPressPoint, timeout); finalizeUiElementOperation(); return isElementTapped; } else { String message = String.format("Point %s not in element bounds.", innerPoint.toString()); LOGGER.error(message); throw new IllegalArgumentException(message); } }
/** * Check if certain {@link Bounds} parameter is inside the bounds. * * @param bounds * - a {@link Bounds} parameter that needs to be contained in the bounds * @return true if the bounds contain the bounds parameter, false otherwise */ public boolean contains(Bounds bounds) { Point boundsUpperLeftCorner = bounds.getUpperLeftCorner(); int boundsWidth = bounds.getWidth(); int boundsHeight = bounds.getHeight(); boolean containsUpperLeftCorner = contains(boundsUpperLeftCorner); boolean containsWidth = boundsUpperLeftCorner.getX() + boundsWidth <= upperLeftCorner.getX() + width; boolean containsHeight = boundsUpperLeftCorner.getY() + boundsHeight <= upperLeftCorner.getY() + height; return containsUpperLeftCorner && containsWidth && containsHeight; }
Point selectorBoundsUpperCorner = selectorBounds.getUpperLeftCorner();
Point selectorBoundsUpperCorner = propertiesContainerBounds.getUpperLeftCorner();
/** * Simulates a pinch in on the element. NOTE emulator devices may not detect pinch gestures on UI elements with size * smaller than 100x100dp. * * @return <code>true</code> if the pinch in is successful, <code>false</code> if it fails * @throws StaleElementReferenceException * if the element has become stale before executing this method */ public boolean pinchIn() { revalidateThrowing(); Bounds elementBounds = propertiesContainer.getBounds(); final int BOUNDS_OFFSET_DENOMINATOR = 10; final int WIDTH_OFFSET = elementBounds.getWidth() / BOUNDS_OFFSET_DENOMINATOR; final int HEIGHT_OFFSET = elementBounds.getHeight() / BOUNDS_OFFSET_DENOMINATOR; // starting the pinch at a distance from the exact bounds of the element so that it will not affect other UI // elements Point lowerRight = elementBounds.getLowerRightCorner(); int firstFingerInitialX = lowerRight.getX() - WIDTH_OFFSET; int firstFingerInitialY = lowerRight.getY() - HEIGHT_OFFSET; Point firstFingerInitial = new Point(firstFingerInitialX, firstFingerInitialY); Point upperLeft = elementBounds.getUpperLeftCorner(); int secondFingerInitialX = upperLeft.getX() + WIDTH_OFFSET; int secondFingerInitialY = upperLeft.getY() + HEIGHT_OFFSET; Point secondFingerInitial = new Point(secondFingerInitialX, secondFingerInitialY); boolean result = (boolean) communicator.sendAction(RoutingAction.GESTURE_PINCH_IN, firstFingerInitial, secondFingerInitial); return result; }
Pair<Integer, Integer> resolution) { Point upperLeftCorner = elementBounds.getUpperLeftCorner(); Point upperRightCorner = elementBounds.getUpperRightCorner(); Point lowerLeftCorner = elementBounds.getLowerLeftCorner();