- All rights of Sikulix and its API belong to the original product providers. Pleaes visit http://sikulix.com/ for more details.
- Codes in project will trigger the downloads of certain Sikulix JAR files through Sikulix provided links.
- You need to agree to the original license agreements with the original product providers directly. This project does not assume any 3rd party licensing responsibility.
This project is licensed under the terms of the MIT license.
This project contains node js code that can make Sikulx API functionality available in Node JS coding environment as well as in Linux system commands.
npm install xysikulixapi # which will download sikulixapi-2.0.4.jar
SikulixApiVer=2.0.3 npm install xysikulixapi # which will download sikulixapi-2.0.3.jar
npm test
or
google-chrome test_images/targetImage.png &
npm run test-positive
npm run test-negative
kill %1
#!/usr/bin/env node
// above: since JVM is a heavy process it is advised to run a separate node process for it.
// Node js property
const java = require('java');
const xysikulixapi = require('xysikulixapi');
// Sikuli property
const App = xysikulixapi.App;
const Region = xysikulixapi.Region;
const Screen = xysikulixapi.Screen;
const Pattern = xysikulixapi.Pattern;
// Prepare target area
var mySampleImagePath = '/full/Path/To/ImageFile'; // define a sample image
var mySimilarity = 0.95; // define similarity as 95%
var myScreen = new Screen(); // get screen 0 (default as 0)
var myScreenRegion = new Region(myScreen.getBoundsSync()); // define a new region from myScreen
// Prepare sample
var myPattern = (new Pattern(mySampleImagePath)).similarSync(java.newFloat(mySimilarity)); // define a Pattern that is 95% similar to the sample image
// Single target and actions
const oneTarget = myScreenRegion.findSync(myPattern); // find one target
oneTarget.highlight(0.1); // flash a highlight on the target
let targetText = oneTarget.textSync(); // retrive text from target
console.log(targetText); // print retrived text
// All targets and actions
const allTargets = myScreenRegion.findAllSync(myPattern); // find all targets
while (allTargets.hasnextSync()) { // loop through all targets
let oneTarget = allTargets.nextSync(); // process each target
...
}
...
Here is a working example