Jump to content
Sign in to follow this  
polaski

Array Mirror and flip.

Recommended Posts

I`ve got little problem with my drawing script.

When detonating that script in paint it just draw a BMP array but flipped by 90 degrees and "mirror image".

I was testing it in winXP mspaint. In other systems just place MouseMove it in diffrent place. 150pix x 150 pix Black&White BMP.

Can some one just rebuild my arrays to get normal image?

MouseMove(105,76,1) in other place.

#cs ----------------------------------------------------------------------------

 AutoIt Version: 3.3.14.0
 Author:         polaski Marcin PRzyborowski

 Script Function: Convert BMP image into Array[x,y]=[Hex colour]
https://www.autoitscript.com/forum/topic/112540-is-there-a-function-for-reading-images-into-2d-arrays/?do=findComment&comment=788472
https://www.autoitscript.com/forum/topic/27362-bitmap-library/
script create an 2d Matrix.

#ce ----------------------------------------------------------------------------


#include <BMP3.au3> ;https://www.autoitscript.com/forum/topic/27362-bitmap-library/
#include <Array.au3>
#include <File.au3>

;;;;;;;;;;;;;;;;;hotkeye;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

; Press Esc to terminate script, Pause/Break to "pause"

Global $g_bPaused = False

HotKeySet("{PAUSE}", "TogglePause")
HotKeySet("{ESC}", "Terminate")

;While 1
;    Sleep(100)
;WEnd

Func TogglePause()
    $g_bPaused = Not $g_bPaused
    While $g_bPaused
        Sleep(100)
        ToolTip('Script is "Paused"', 0, 0)
    WEnd
    ToolTip("")
EndFunc   ;==>TogglePause

Func Terminate()
    Exit
EndFunc   ;==>Terminate



;;;;;;;;;;;;;;;;;hotkey end;;;;;;;;;;;;;;;;;;;;;;;;;;;
;Global $Paused


Local $filename = FileOpenDialog("Select image", @DesktopCommonDir, "All images (*.jpg;*.png;*.gif;*.bmp;)", 1)

$bmp = _BMPOpen($filename,1) ;zwraca uchwyt do bitmapy która otworzylismy.


Dim $tab3d[$bmp[1]][$bmp[2]] ;tablica o wymiarach bitmapy

;;;pętla zbierająca pixele;;;;
For $j = 0 To $bmp[1] - 1
        For $i = 0 To $bmp[2] - 1
           $tab3d[$j][$i]=_PixelRead($bmp,$j,$i)
         Next
      Next



      ;hójowa tablica 6 na 6
Global $glebokosc = 0
Global $kolor = 0
Global $pamiec = 0
Global $w1


call(start)
call (czytaj)


func start()


 If WinExists("[CLASS:MSPaintApp]") Then
      WinKill("[CLASS:MSPaintApp]", "")
        ;WinKill("Kolko i Krzyzyk")
     EndIf

Run("mspaint.exe")

$hWnd =  WinWait("[CLASS:MSPaintApp]", "",2)
sleep(2000)
 WinMove("[CLASS:MSPaintApp]",  "", 0, 0, 1000, 1000)

Sleep(10000)

MouseMove(105,76,1)

EndFunc




func czytaj()
For $j = 0 to $bmp[1] - 1
   $w1=MouseGetPos()
        For $i = 0 To $bmp[2] - 1


$pamiec=$glebokosc
;$kolor=$tab3d[$j][$i]

if $tab3d[$j][$i]='000000' Then
   call(wierc)

while $i < $bmp[2]-1 And $tab3d[$j][$i]=$tab3d[$j][$i+1]
$i=$i+1
;if $i=$bmp[2] then ExitLoop
;if $i=$bmp[2]-1 then ExitLoop

;_ArrayDisplay ($tab3d)
MouseDown ( "left" )
call(posowaj)
WEnd
MouseUP ("left")


   call(wyciagaj)
   call(posowaj)
   EndIf


if $tab3d[$j][$i]='FFFFFF' Then
   call(posowaj)
EndIf


Next
call(wroc)
Next

EndFunc

Func wierc()
Local $w2=mousegetpos()
MouseClick ("left", $w2[0],$w2[1]  , 1 ,  1 )
;beep(300,300)
EndFunc


Func wyciagaj()
Local $w2=mousegetpos()
;MouseClick ("right", $w2[0],$w2[1]  , 1 ,  1 )
;beep(800,300)
EndFunc

Func posowaj()
Local $w2=mousegetpos()
MouseMove ($w2[0]+2,$w2[1] , 0 )

EndFunc


func wroc()
    MouseMove ( $w1[0],$w1[1]+2  , 0 )
EndFunc

 

 

 

Edited by polaski

Share this post


Link to post
Share on other sites

Try this code:

#include <BMP3.au3> ;https://www.autoitscript.com/forum/topic/27362-bitmap-library/
#include <Array.au3>
#include <File.au3>

Global $g_bPaused = False

HotKeySet("{PAUSE}", "TogglePause")
HotKeySet("{ESC}", "Terminate")

Func TogglePause()
  $g_bPaused = Not $g_bPaused
  While $g_bPaused
    Sleep(100)
    ToolTip('Script is "Paused"', 0, 0)
  WEnd
  ToolTip("")
EndFunc

Func Terminate()
    Exit
EndFunc

Local $filename = FileOpenDialog("Select image", @DesktopCommonDir, "All images (*.jpg;*.png;*.gif;*.bmp;)", 1)
$bmp = _BMPOpen($filename,1) ;zwraca uchwyt do bitmapy która otworzylismy.

Dim $tab3d[$bmp[2]][$bmp[1]]

For $i = 0 To $bmp[1] - 1
  For $j = 0 To $bmp[2] - 1
    $tab3d[$j][$i]=_PixelRead($bmp,$i,$j)
  Next
Next

If WinExists("[CLASS:MSPaintApp]") Then _
  WinKill("[CLASS:MSPaintApp]", "")
Run("mspaint.exe")
$hWnd =  WinWait("[CLASS:MSPaintApp]", "",2)
sleep(200)
WinMove("[CLASS:MSPaintApp]",  "", 0, 0, 1000, 1000)
Sleep(200)
MouseMove(105,76,1)
  
Local $w1, $w2
For $i = 0 to $bmp[2] - 1
  $w1=MouseGetPos()
  For $j = 0 To $bmp[1] - 1
    if $tab3d[$i][$j]='000000' Then
      Local $w2=MouseGetPos()
      MouseClick( "left", $w2[0],$w2[1], 1, 1 )
      while $j < $bmp[2]-1 And $tab3d[$i][$j] = $tab3d[$i][$j+1]
        $j += 1
        MouseDown( "left" )
        $w2 = MouseGetPos()
        MouseMove( $w2[0]+2, $w2[1], 0 )
      WEnd
      MouseUp("left")
      $w2 = MouseGetPos()
      MouseMove( $w2[0]+2, $w2[1], 0 )
    EndIf
    if $tab3d[$i][$j]='FFFFFF' Then
      $w2 = MouseGetPos()
      MouseMove( $w2[0]+2, $w2[1], 0 )
    EndIf
  Next
  MouseMove( $w1[0], $w1[1]+2, 0 )
Next

 

Share this post


Link to post
Share on other sites

Thanks. Solved. I will try to use that code to program my CNC drill :).

It helps me alot to understand: how read arrays better.

Share this post


Link to post
Share on other sites

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 account

Sign in

Already have an account? Sign in here.

Sign In Now
Sign in to follow this  

  • Similar Content

    • By jmp
      Script running good but error in line 7.
      When i run this script :
      #include <IE.au3> #include <Array.au3> $oIE = _IEAttach ("Shop") $oTable = _IETableGetCollection ($oIE, 1) $aTableData = _IETableWriteToArray ($oTable) For $inumber = 1 To UBound($aTableData) -1 $table = $aTableData[4][$inumber] MsgBox(0, "", $table) Next I got Error: array variable has incorrect number of subscripts or subscript dimension range exceeded
    • By nacerbaaziz
      Good morning guys, i hope that you're all well.
      guys, i have a problem and i hope that you can help me
      i've created an 3d array
      the array Contain a Categories info
      as folow
      $array[n][0][0] = Categorie name
      $array[n][0][1] = Categorie file path
      $array[n][0][2] = Categorie contents number
      $array[n][m][0] = link name
      $array[n][m][1] = link url
      $array[n][m][2] = link section name
      in my tool i want to add an option to delete a Category
      as you know the Categorie mean that must delete a region from the array
      when i tried to use _arrayDelete
      with the 2d array it work well
      but here i couldn't find any way to do that, can any one help me please?
      thanks in advance.
    • By nacerbaaziz
      hello sirs, please help me
      i tried to create a function that read a folder files to 3d array
      e.g
      $array[n][0][0] = ctName
      $array[n][0][1] = ctFilePath
      $array[n][0][2] = crtsections number
      $array[n][m][0] = KeyName
      $array[n][m][1] = KeyVal
      $array[n][m][2] = keySectionName
       
      that the array
      when i put one file into the folder all things work fine
      but when i put more than one file
      the last file worked fine but the others only the first key is showing
      please can you help me to correct this problem
      here is the example with the folder
      please accept my greetings
      and thanks in advance
       
      array3d.zip
    • By nacerbaaziz
      good morning everybody.
      today i liked to share an small example with you
      which it an function to read the registry values as an array
      the result array is 2d array witch
      $a_array[n][0] = value name
      $a_array[n][1] = value Data
      $a_array[0][0] = values count
      here's the function

      #include <Array.au3> #include <WinAPIReg.au3> #include <APIRegConstants.au3> Local $a_array = _RegReadToArray("HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Run") If @error Then     MsgBox(16, "error", @error)     Exit EndIf _ArrayDisplay($a_array) Func _RegReadToArray($s_RegKey)     Local $a_KeySplitInfo = StringSplit($s_RegKey, "\\", 2)     If UBound($a_KeySplitInfo) <= 1 Then         $a_KeySplitInfo = StringSplit($s_RegKey, "\", 2)         If UBound($a_KeySplitInfo) <= 1 Then Return (1, 1, 0)     EndIf     Local $H_KeyInfo = "", $s_RegKeyInfo = ""     Switch $a_KeySplitInfo[0]         Case "hklm", "HKEY_LOCAL_MACHINE", "hklm64", "HKEY_LOCAL_MACHINE64"             $H_KeyInfo = $HKEY_LOCAL_MACHINE         Case "hkCu", "HKEY_CURRENT_USER", "hkCU64", "HKEY_CURRENT_USER64"             $H_KeyInfo = $HKEY_CURRENT_USER         Case "hkCr", "HKEY_CLASSES_ROOT", "HKCR64", "HKEY_CLASSES_ROOT64"             $H_KeyInfo = $HKEY_CLASSES_ROOT         Case "HKU", "HKEY_USERS", "HKU64", "HKEY_USERS64"             $H_KeyInfo = $HKEY_USERS         Case Else             Return SetError(2, 2, 0)     EndSwitch     _ArrayDelete($a_KeySplitInfo, 0)     $s_RegKeyInfo = _ArrayToString($a_KeySplitInfo, "\")     Local $H_KeyInfoOpen = _WinAPI_RegOpenKey($H_KeyInfo, $s_RegKeyInfo, $KEY_READ)     Local $A_KeyInfo = _WinAPI_RegQueryInfoKey($H_KeyInfoOpen)     If @error Then Return SetError(1, 1, 0)     _WinAPI_RegCloseKey($H_KeyInfoOpen)     Local $A_RegVal[$A_KeyInfo[2] + 1][2]     Local $iV = 1, $s_RegRead = ""     While 1         $s_RegVal = RegEnumVal($s_RegKey, $iV)         If @error <> 0 Then ExitLoop         $s_RegRead = RegRead($s_RegKey, $s_RegVal)         If Not (@error) Then             $A_RegVal[$iV][0] = $s_RegVal             $A_RegVal[$iV][1] = $s_RegRead         EndIf         $iV += 1     WEnd     $A_RegVal[0][0] = UBound($A_RegVal) - 1     If $A_RegVal[0][0] >= 1 Then         Return $A_RegVal     Else         Return SetError(3, 3, 0)     EndIf EndFunc   ;==>_RegReadToArray
      i hope you benefit from it
      with my greetings
    • By JackER4565
      Hi, first of all thanks to all the guys who always help people in the forums, I wouldn't be able to do anything if wasn't for your help, even if I don't ask it myself.
       
      I've created this code to get some info on a monitoring network on my work. It relays on _IETableGetCollection and _IETableWriteToArray.
      It works well, but take around 3:25 minutes to get the info from 28 pages (some of them are large and take longer to load, but most of them are small and fast).
      My question is if you see a way to get the program to go faster...
       
      I've tried to make it easy for you to understand and edited somethings with sensitive info.
      (Some of the pages doesn't have the black divider with MIRA in the end, so I need to search if it is there or not.)
       
      #include <IE.au3> #include <array.au3> Local $oIE = _IECreate("about:blank", 0, 0) Local $paginas[28] = [89, 90, 91, 92, 93, 96, 105, 113, 119, 125, 126, 129, 131, 133, 135, 137, 139, 140, 141, 144, 145, 146, 148, 149, 150, 151, 158, 159] Local $Datos_array[0][2] Local $oTable Local $tabla Local $aux_x = 1 Local $ar = 1 Local $Numtables_datos = 0 MsgBox(0, "asd", "asd") For $pag = 0 To UBound($paginas) - 1 Step 1 _IENavigate($oIE, "<WEBSITE URL>" & $paginas[$pag]) ; <<< the pages to load are always the same except for the last digits. _ArrayAdd($Datos_array, $paginas[$pag] & "|" & "Entrante", 0, "|") ; <<<<<<<<<<<<<<<< adds the page number toarray [0, 0] ;############################################ START counts amount of tables with traffic $oTable = _IETableGetCollection($oIE) Local $iNumTables = @extended For $i = 3 To $iNumTables - 2 Step 1 $oTable = _IETableGetCollection($oIE, $i) $nomb_tabla2 = _IETableWriteToArray($oTable) ; <<<<<<<< TABLE TO ARRAY. $string2 = StringStripWS($nomb_tabla2[1][0], 8) If $string2 <> "MIRA" Then $Numtables_datos = $Numtables_datos + 1 Next $tabla_End = $iNumTables - $Numtables_datos ;############################################ FIN $tabla_Start = 4 $tabla_trafico = 2 For $for = 1 To $Numtables_datos Step 1 $oTable = _IETableGetCollection($oIE, $tabla_Start - 1) ; <<<<<<<<<<< NAME OF THE TABLE; row2 = mira $nomb_tabla = _IETableWriteToArray($oTable) ; <<<<<<<< TABLE TO ARRAY ;########################################### ADDS the traffic number into the row $string = StringStripWS($nomb_tabla[1][0], 8) If $string == "MIRA" Then ;si o si pasa por aca 1 vez _ArrayAdd($Datos_array, $nomb_tabla[0][0]) $nomb_aux = $nomb_tabla[0][0] $aux_x = 1 $tabla_trafico = $tabla_trafico + 2 Else ;esto deberia ser por row _ArrayAdd($Datos_array, $nomb_aux & " " & $aux_x) $aux_x = $aux_x + 1 $tabla_trafico = $tabla_trafico + 1 EndIf $oTable = _IETableGetCollection($oIE, $tabla_trafico) Local $aTableData = _IETableWriteToArray($oTable) $bps = _ArrayToString($aTableData, "|", 0, 0, @CRLF, 0, 0) $bps = StringRight($bps, 5) $bps = StringLeft($bps, 4) $trafico_actual = _ArrayToString($aTableData, "|", 0, 0, @CRLF, 2, 2) If $bps == "Gbps" Then $trafico_actual = $trafico_actual * 1000 If $bps == "Kbps" Then $trafico_actual = $trafico_actual / 1000 $Datos_array[$ar][1] = $trafico_actual $ar = $ar + 1 If $string == "MIRA" Then $tabla_Start = $tabla_Start + 2 Else $tabla_Start = $tabla_Start + 1 EndIf Next $ar = $ar + 1 ;~ ############# CAÍDA ############ ;~ If $actual_entrante = 0 Then ;~ $xxx = 0 ;~ Do ;~ MsgBox(0, "Tráfico Caído", $paginas[$i], 5) ;~ $xxx = $xxx + 1 ;~ Until $xxx = 10 ;~ EndIf ;~ ############# CAÍDA ############. Local $Numtables_datos = 0 Next _ArrayDisplay($Datos_array, "Array display") _IEQuit($oIE) Thanks!! 


      monitoria.html
×
×
  • Create New...