Burgaud Posted May 8, 2014 Share Posted May 8, 2014 Hi I am new to AutoIt and this is my problem: func ScanPick ($color,$timeout,$x) Local $aCoord[2] $aCoord = PixelSearch(660,180,1260,780, $color, 2) Wait(100) print(stringformat("%d %d",$aCoord[0], $aCoord[1])) if Not @error then MouseClick("left", $aCoord[0], $aCoord[1]) print(StringFormat("Looting Item [%d]",$x+1)) Wait($timeout) return(1) else return(0); endif endfunc I could not get it to access $aCoord[0], $aCoord[1] I keep getting: Error: Subscript used on non-accessible variable on the Print; what gives? Same problem with the MouseClick statement, I simply could not access $aCoord[0] with the error indicating "[" as error??? Need help Link to comment Share on other sites More sharing options...
Moderators Melba23 Posted May 8, 2014 Moderators Share Posted May 8, 2014 (edited) Burgaud,It sounds as if the PixelSearch function is not returning an array - I suggest you do some error-checking (with IsArray) before trying to access the array elements. M23Edit: Welcome to the AutoIt forums by the way. Edited May 8, 2014 by Melba23 Any of my own code posted anywhere on the forum is available for use by others without any restriction of any kind Open spoiler to see my UDFs: Spoiler ArrayMultiColSort ---- Sort arrays on multiple columnsChooseFileFolder ---- Single and multiple selections from specified path treeview listingDate_Time_Convert -- Easily convert date/time formats, including the language usedExtMsgBox --------- A highly customisable replacement for MsgBoxGUIExtender -------- Extend and retract multiple sections within a GUIGUIFrame ---------- Subdivide GUIs into many adjustable framesGUIListViewEx ------- Insert, delete, move, drag, sort, edit and colour ListView itemsGUITreeViewEx ------ Check/clear parent and child checkboxes in a TreeViewMarquee ----------- Scrolling tickertape GUIsNoFocusLines ------- Remove the dotted focus lines from buttons, sliders, radios and checkboxesNotify ------------- Small notifications on the edge of the displayScrollbars ----------Automatically sized scrollbars with a single commandStringSize ---------- Automatically size controls to fit textToast -------------- Small GUIs which pop out of the notification area Link to comment Share on other sites More sharing options...
butterfly Posted May 8, 2014 Share Posted May 8, 2014 Welcome to the Forum I believe this should be correct! func ScanPick ($color,$timeout,$x) Local $aCoord[2] $aCoord = PixelSearch(660,180,1260,780, $color, 2) Wait(100) if IsArray($aCoord) Then print(stringformat("%d %d",$aCoord[0], $aCoord[1])) MouseClick("left", $aCoord[0], $aCoord[1]) print(StringFormat("Looting Item [%d]",$x+1)) Wait($timeout) return(1) else ConsoleWrite(@error & @LF) return(0); EndIf endfunc Link to comment Share on other sites More sharing options...
Burgaud Posted May 8, 2014 Author Share Posted May 8, 2014 (edited) Got it! I was relying so much on Not if Not @error then But it appears it is not working Thanks! PS. Loving AutoIT! Edited May 8, 2014 by Burgaud Link to comment Share on other sites More sharing options...
JohnOne Posted May 8, 2014 Share Posted May 8, 2014 @error works just fine but I suspect you're testing it in the wrong place. @error is set to 0 upon entering all functions including those you define yourself. AutoIt Absolute Beginners Require a serial Pause Script Video Tutorials by Morthawt ipify Monkey's are, like, natures humans. Link to comment Share on other sites More sharing options...
Recommended Posts
Create an account or sign in to comment
You need to be a member in order to leave a comment
Create an account
Sign up for a new account in our community. It's easy!
Register a new accountSign in
Already have an account? Sign in here.
Sign In Now