All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.sikuli.script.Pattern Maven / Gradle / Ivy

There is a newer version: 2.0.5
Show newest version
/*
 * Copyright (c) 2010-2016, Sikuli.org, sikulix.com
 * Released under the MIT License.
 *
 */
package org.sikuli.script;

import org.sikuli.basics.Settings;
import java.awt.image.BufferedImage;
import java.net.URL;

/**
 * to define a more complex search target
* - non-standard minimum similarity
* - click target other than center
* - image as in-memory image */ public class Pattern { static RunTime runTime = RunTime.get(); private Image image = null; private float similarity = (float) Settings.MinSimilarity; private Location offset = new Location(0, 0); private int waitAfter = 0; private boolean imagePattern = false; /** * creates empty Pattern object at least setFilename() or setBImage() must be used before the * Pattern object is ready for anything */ public Pattern() { } /** * create a new Pattern from another (attribs are copied) * * @param p other Pattern */ public Pattern(Pattern p) { image = p.getImage(); similarity = p.similarity; offset.x = p.offset.x; offset.y = p.offset.y; imagePattern = image.isPattern(); } /** * create a Pattern with given image
* * @param img Image */ public Pattern(Image img) { image = img.create(img); image.setIsPattern(false); imagePattern = true; } /** * true if Pattern was created from Image * @return true/false */ public boolean isImagePattern() { return imagePattern; } /** * create a Pattern based on an image file name
* * @param imgpath image filename */ public Pattern(String imgpath) { image = Image.create(imgpath); } /** * Pattern from a Java resource (Object.class.getResource) * * @param url image file URL */ public Pattern(URL url) { image = Image.create(url); } /** * A Pattern from a BufferedImage * * @param bimg BufferedImage */ public Pattern(BufferedImage bimg) { image = new Image(bimg); } /** * A Pattern from a ScreenImage * * @param simg ScreenImage */ public Pattern(ScreenImage simg) { image = new Image(simg.getImage()); } /** * check wether the image is valid * * @return true if image is useable */ public boolean isValid() { return image.isValid() || imagePattern; } /** * set a new image for this pattern * * @param fileName image filename * @return the Pattern itself */ public Pattern setFilename(String fileName) { image = Image.create(fileName); return this; } /** * set a new image for this pattern * * @param fileURL image file URL * @return the Pattern itself */ public Pattern setFilename(URL fileURL) { image = Image.create(fileURL); return this; } /** * set a new image for this pattern * * @param img Image * @return the Pattern itself */ public Pattern setFilename(Image img) { image = img; return this; } /** * the current image's absolute filepath *
will return null, if image is in jar or in web *
use getFileURL in this case * * @return might be null */ public String getFilename() { return image.getFilename(); } /** * the current image's URL * * @return might be null */ public URL getFileURL() { return image.getURL(); } /** * sets the minimum Similarity to use with findX * * @param sim value 0 to 1 * @return the Pattern object itself */ public Pattern similar(float sim) { similarity = sim; return this; } /** * sets the minimum Similarity to 0.99 which means exact match * * @return the Pattern object itself */ public Pattern exact() { similarity = 0.99f; return this; } /** * * @return the current minimum similarity */ public float getSimilar() { return this.similarity; } /** * set the offset from the match's center to be used with mouse actions * * @param dx x offset * @param dy y offset * @return the Pattern object itself */ public Pattern targetOffset(int dx, int dy) { offset.x = dx; offset.y = dy; return this; } /** * set the offset from the match's center to be used with mouse actions * * @param loc Location * @return the Pattern object itself */ public Pattern targetOffset(Location loc) { offset.x = loc.x; offset.y = loc.y; return this; } /** * * @return the current offset */ public Location getTargetOffset() { return offset; } /** * ONLY FOR INTERNAL USE! Might vanish without notice! * * @return might be null */ public BufferedImage getBImage() { return image.get(); } /** * ONLY FOR INTERNAL USE! Might vanish without notice! * * @param bimg BufferedImage * @return the Pattern object itself */ public Pattern setBImage(BufferedImage bimg) { image = new Image(bimg); return this; } /** * sets the Pattern's image * * @param img Image * @return the Pattern object itself */ public Pattern setImage(Image img) { image = img; return this; } /** * get the Pattern's image * * @return Image */ public Image getImage() { return image; } /** * set the seconds to wait, after this pattern is acted on * * @param secs seconds */ public void setTimeAfter(int secs) { waitAfter = secs; } /** *
TODO: Usage to be implemented! * get the seconds to wait, after this pattern is acted on * @return time in seconds */ public int getTimeAfter() { return waitAfter; } @Override public String toString() { String ret = "P(" + image.getName() + (isValid() ? "" : " -- not valid!") + ")"; ret += " S: " + similarity; if (offset.x != 0 || offset.y != 0) { ret += " T: " + offset.x + "," + offset.y; } return ret; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy