Global ObjectScanning and DetectionFactory Global

Region(x, y, w, h)

Region manages screen scanning, image matching, and detection flow. It also behaves as a callable global factory.

Detailed Explanation

This section explains when to use the API, how to call it, and which structures it works best with in production flow.

What It Does

Region(x, y, w, h) is the main entry point for this object family. Use it to understand the responsibility of the namespace before diving into the methods below it. Region manages screen scanning, image matching, and detection flow. It also behaves as a callable global factory.

When To Use It

In detection flow, refresh the screen with Snap.screenRefresh() first, then narrow the search area and confidence using Region and FindParam. This API becomes most valuable in screen-driven decision scenarios.

Parameters and Return

x, y, w, h define the purpose of the call; preparing them in clearly named variables before execution makes production debugging easier. This entry is a namespace or helper object overview; the real flow is built with the methods listed below it.

Best Combined With

It is typically combined with Snap, Region, Asset, and FindParam; you can feed the result into quickTap(), click(), or a follow-up OCR step.

Example Usage

The snippet below is a starter pattern that can be applied directly in runtime flow.

local area = Region()
local hit = area:find(Asset.image("ok_btn"))
if hit then quickTap(hit) end

Copyable Progressive Examples

From foundation to combined usage, each level is provided as a separate code block so you can copy the level you need and adapt it directly.

Foundation

Shows the shortest direct way to call the API.

Foundation
local area = Region()
local hit = area:find(Asset.image("ok_btn"))
if hit then quickTap(hit) end

Simple

Wraps the base call with minimal flow control.

Simple
local area = Region()
local hit = area:find(Asset.image("ok_btn"))
if hit then quickTap(hit) end

-- Continue with one focused method on the object.

Practical Flow

A practical pattern for real macros with pcall, logging, and guards.

Practical Flow
local area = Region()
local hit = area:find(Asset.image("ok_btn"))
if hit then quickTap(hit) end
local note = "Region overview loaded"
print(note)

Detailed

This level packages the API into a reusable helper with error reporting.

Detailed
-- In detection flow, refresh the screen with Snap.screenRefresh() first, then narrow the search area and confidence using Region and FindParam.
local function run_region_step()
  local area = Region()
  local hit = area:find(Asset.image("ok_btn"))
  if hit then quickTap(hit) end
end

local ok, err = pcall(run_region_step)
if not ok then
  toast("Step failed")
  print(err)
end

Combined

Combines the API with related structures to form a more realistic workflow.

Combined
Snap.screenRefresh()
local region = Region()
local param = FindParam.timeout(3000)

local result = region:find(Asset.image("target"), param)
if result then
  quickTap(result)
  wait(250)
  toast("Detection step completed")
end