Dominating an Online Game with Object Detection Using OpenCV - Template Matching.

Поделиться
HTML-код
  • Опубликовано: 23 ноя 2024

Комментарии • 499

  • @williamrutherford553
    @williamrutherford553 3 года назад +363

    Great video, love to see more like this. Automating games like this is an amazing way to introduce people to OpenCV, it's simple to explain but teaches you important skills applicable to a much wider range of tasks. I'm glad I randomly stumbled upon your channel, your videos don't get nearly as many views as it deserves for such high quality educational content.

    • @ClarityCoders
      @ClarityCoders  3 года назад +9

      Glad you enjoyed it! I'll have more coming soon!

    • @yichong777
      @yichong777 3 года назад +4

      I agree, I had my first coding experience from minecraft because I wanted to automate a turtle in the modded game xD

    • @ClarityCoders
      @ClarityCoders  3 года назад +6

      @@yichong777 Thanks for the comment it means a lot. I was getting beat up a bit today haha...

    • @bobchelios9961
      @bobchelios9961 3 года назад +3

      i bascily became a programmer by starting to atuomate games. learned many skills from basic programming to ocr to stock market theroies to reinforcement learning while doing that.

    • @johndorian4078
      @johndorian4078 3 года назад +1

      @@bobchelios9961 So did i....... which is why it's kind of a shame some games are so quick to ban.

  • @ArcaneEther
    @ArcaneEther 3 года назад +128

    To circumvent the missed image detection from a day/night cycle, you can add a desaturation to both your sample and comparison images to grayscale them before comparison.
    This usually works for pixel-based art styles, as day/night is usually just an added color filter over the original image.
    The exception being those games that use specular or bloom lighting effects, which can distort the end-result grayscale in the image.
    The trade off, however, is that the added step of desaturating the sample image on each frame will slow down the script a bit.
    EDIT: This method also wouldn't work in games that reuse sprites with different color palettes, for obvious reasons.

    • @ClarityCoders
      @ClarityCoders  3 года назад +13

      Yes sir! Very good points this is something I've used in a few projects and probably should have talked about! Great comment.

    • @mrhitsjr4775
      @mrhitsjr4775 3 года назад

      hey could you help make a open cv for shooting the ball in nba 2k

    • @andrjsjan4231
      @andrjsjan4231 11 месяцев назад

      I didn’t get it why do they use different color palettes for different reasons?

    • @ChrisCox-wv7oo
      @ChrisCox-wv7oo 7 месяцев назад +1

      Differentiate objects by color is a cost effective way of expanding the object types in game.
      Red goblins are fire goblins.
      Blue goblins are ice goblins.
      If you want to use flame thrower on red goblins, and water gun on blue goblins, you need to be able to determine type you're identifying.
      That's the issue discussed above.

  • @Primu
    @Primu 10 месяцев назад +7

    15:15 A more efficient solution here would be to just check for rectangles with intersecting regions. Not sure about python but in c# this is very simple with the Rect.IntersectsWith method (you can also just do it manually, the math is easy). Then you can combine them by inflating one rect with the difference from the other.
    Also for more reliable matching, there are various imaging algorithms you can use, for my OCR projects I do: grayscale > scaling > binarization > inversion > denoise > bordering, this helps a lot for matching foreground objects over varying backgrounds. You can also start with colour averaging which can make scanning for objects significantly faster at higher resolutions because you can scan chunks of the image and skip processing any that aren't similar. I've used these methods for overlaying real-time translation of text in non-english games.

  • @mdellertson
    @mdellertson 3 года назад +29

    Amazing work! Thank you so much for sharing this! I would love to see a video on how to implement convolutional neural networks to do object recognition.

  • @AlgorithmAlloy
    @AlgorithmAlloy 3 года назад +11

    You could have also done the grouping by comparing the distances of all rectangle centroids which would essentially create a node graph with every center connected to everyother center and then combining all nodes whose distance is below some threshold distance. Your solution works, I just think it’s good practice to use more general algorithms.

    • @ClarityCoders
      @ClarityCoders  3 года назад +4

      I would agree very good points. Thanks for watching and commenting.

  • @BusinessWolf1
    @BusinessWolf1 3 года назад +6

    Here's an idea to get around the different shades thing: transform all target images to black and white, and same with the recording output going into the program.

    • @gnack420
      @gnack420 3 года назад

      Different colours will end up as different shades of grey though. The correct approach is what the library already does, which is normalisation.

    • @BusinessWolf1
      @BusinessWolf1 3 года назад +1

      @@gnack420 Shades imply there's color. What you wanted to say was value (lightdark). Sorry I got into definitions. But yeah, you're right. I wrote that comment before finishing the video, I didn't know you were gonna use an algorithm to find likely matches, I thought that whould require some deep learning or something much more advanced. Shows how much I know about programming. Oh, and btw, thanks for the video, it was really fun!

  • @pfever
    @pfever 3 года назад +26

    Your videos are awesome man! I really love them :D

    • @ClarityCoders
      @ClarityCoders  3 года назад +1

      Mean a lot thanks. I really appreciate the view and comment have a good one.

  • @Beatsbasteln
    @Beatsbasteln 3 года назад +279

    3:34 "now my hope is that we detect multiple instances of weed"
    yes pls!

    • @NoshNosher
      @NoshNosher 3 года назад +19

      except he clearly says wheat

    • @Beatsbasteln
      @Beatsbasteln 3 года назад +2

      @@NoshNosher are you sure about that bro?

    • @ells101
      @ells101 3 года назад

      @@NoshNosher Charles Shwab ova here

    • @emifro
      @emifro 3 года назад +4

      @@Beatsbasteln I am 100% sure he said wheat.

    • @Beatsbasteln
      @Beatsbasteln 3 года назад +5

      @@emifro but how are you going to smoke wheat?

  • @DarkNemesis04
    @DarkNemesis04 3 года назад +11

    This is a really well paced and detailed guide! Great work :)

    • @ClarityCoders
      @ClarityCoders  3 года назад +2

      Thanks I work really hard on trying to figure out the best pace to keep people engaged and still not skip topics. I will continue to try and improve. Thanks for commenting and watching.

  • @mohammedyasser3189
    @mohammedyasser3189 2 месяца назад

    man!!!!
    your are amazing
    we need more of this content with this type of teaching methods

  • @djbroake9810
    @djbroake9810 2 года назад +2

    Thank for the examples and how it all works, liked and subbed.

  • @leonhardguss8150
    @leonhardguss8150 3 года назад +17

    Thank you man, this is awesome !!

    • @ClarityCoders
      @ClarityCoders  3 года назад

      Glad you liked it thanks for watching!

  • @fenfire3824
    @fenfire3824 11 месяцев назад

    Ah thank you so much, i was looking for a tutorial like this for a very long time :) I did something similiar in auto it just for fun, but I always wanted do something like that in a "real" programming language with more powerful libraries. Thank you so much =)
    I only need to learn how to use it in 3d games /video capturing. But it is just fine to learn right from the start :)

  • @cosmicdive
    @cosmicdive 11 месяцев назад +1

    Great tutorial, really enjoy and appreciate you explain what each line does in detail. Subscribed and liked!

  • @stevesteverson3345
    @stevesteverson3345 3 года назад +6

    haha this is awesome, i've thought about doing it before and after this i might have to. One of the most relatable/interesting coding videos lmao.

    • @ClarityCoders
      @ClarityCoders  3 года назад

      glad you liked it! I hope you do please share it if you do.

    • @stevesteverson3345
      @stevesteverson3345 3 года назад

      @@ClarityCoders I already did :) although apparently the only way to grow small channels these days is to leave comments on a bunch of related videos so people click on your profile.

    • @ClarityCoders
      @ClarityCoders  3 года назад

      @@stevesteverson3345 Trying to grow your channel?

    • @stevesteverson3345
      @stevesteverson3345 3 года назад

      @@ClarityCoders hahah yeah come watch any of my 0 videos

  • @joshuaolsen8844
    @joshuaolsen8844 3 года назад +3

    I love to see you doing these videos! I’d like to see one that is based on real pictures, like “is the car pointed left or right” etc and incorporate some training and AI

    • @ClarityCoders
      @ClarityCoders  3 года назад +2

      Cool idea! I'll put it on my list.

  • @maxfrischdev
    @maxfrischdev 3 года назад

    Oh, come on.. I just decided "Ah crap, just get started..(!) Ima start with the basic webstack and see from there.
    And then I stumbled over this channel and THIS video..
    Great video @ClarityCoders!

  • @elonmed
    @elonmed 2 года назад +1

    thanks man. I love your teaching style

  • @prevensie
    @prevensie 3 года назад

    Teaching archivement unlocked! congrats man! you are helping people from brazil!

    • @ClarityCoders
      @ClarityCoders  3 года назад +1

      I am from a tiny town in the US never thought people would watch me in Brazil. Thanks for watching and commenting.

    • @TheBuzz3r
      @TheBuzz3r 3 года назад

      @@ClarityCoders 🇧🇷

  • @franzdizon8659
    @franzdizon8659 3 года назад

    this is what I have been looking for... THANK YOUUUU

  • @RogerCh888
    @RogerCh888 Год назад

    This is an awesome, very straightforward tutorial. Thank you!

  • @aowmovies8657
    @aowmovies8657 9 месяцев назад +1

    Hey bro, you can google mines game usually available in rummy apps. How to create mines game bot? To make all cells visible by seeing all hidden covered mines inside cells/grid or uncover then through any method or using OpenCv(image recognition) algorithm method to identify exact mines in the cells/grid? Can you make that tutorial?

  • @rastatugan
    @rastatugan 3 года назад +4

    Pretty clear and very interesting, coming from C and learning Python and opencv for industrial purpose, you helped me a lot , template matching can be used in so many way in my work. you have all my respect and i'll follow you with great joy. Thanks again for your videos.

    • @ClarityCoders
      @ClarityCoders  3 года назад

      This comment really means a lot to me. Thanks for watching and commenting I'll keep making videos.

  • @youcandoit4502
    @youcandoit4502 3 года назад +23

    Hi brother is it possible for you to make a chess bot with opencv as u make for other games or for knife hit game if yes please make a video on it .It will be really helpful .

    • @ClarityCoders
      @ClarityCoders  3 года назад +6

      Sure let me see what I can do! Hit that bell so you don't miss it.

    • @youcandoit4502
      @youcandoit4502 3 года назад

      ohh I already done that as I like your content so much and thanks it really means a lot.

    • @Ali-Britco
      @Ali-Britco 3 года назад +2

      @@grzegorzabedzki2989 awesome work, very readable code, even though I have no interest in chess.

    • @billowen3285
      @billowen3285 3 года назад

      @@ClarityCoders please don't, chess sucks with cheaters. And if you must, at least don't release the code

  • @ihatechocolate6621
    @ihatechocolate6621 3 месяца назад

    I love this video and the idea, I don't know anything about coding but if you would every take a look at the game called "Parking master multiplayer 2" (the game requires a lot of repetition plays in order to have money, I would love to see you make a video about that game of how you would set up for it to auto drive the car into the parking spot!!

  • @Conqueror1807
    @Conqueror1807 3 года назад +3

    Here after watching CS Dojo's video :)

  • @ruangustavomoretti766
    @ruangustavomoretti766 2 года назад

    Thanks man, you saved my graduation project!

  • @Raid77
    @Raid77 3 года назад +6

    Amazing tutorial although I do have some ideas to improve some of what was presented,
    Firstly the rectangles grouping section, I'm sure there's a better way than just duplicating the list, maybe manually comparing the x, y of rectangles and if they are similar to another rectangle we don't use it
    The other point would be about beating the highscore, i would test for a single pixel's color above the player on each side where the background is static and check if it's color changes (a branch is above) and move accordingly

  • @saidalizade1291
    @saidalizade1291 Год назад

    Ty very much, i could not find someone explain this as well as you did ngl saved me

  • @USBEN.
    @USBEN. 3 года назад +1

    Very fun to watch and learned a lot. Thankyou.

    • @ClarityCoders
      @ClarityCoders  3 года назад +1

      Thanks for watching/commenting it means a lot.

  • @chuifrankz2070
    @chuifrankz2070 2 года назад

    best tuto about template match i have ever seen!helpful!

  • @CharlesWeill
    @CharlesWeill 3 года назад +1

    I'm loving your content! As a fellow ML engineer, and fan on mini online games, I love this!

    • @ClarityCoders
      @ClarityCoders  3 года назад

      Thanks! I really appreciate the feedback and views!

  • @CapnSlipp
    @CapnSlipp 3 года назад

    You can also find the wheat points without overlaps by running a local maxima filter on the grayscale image- accomplished in OpenCV with a dilate filter followed by a compare filter. You might not need it for this use-case, but you can also additionally filter out plateaus of local maximum value with an erode and a compare (if you want to know what to compare against what, for the sake of brevity here either google it or just try a few combinations; heck, you don’t need Jupyter to figure out the correct operations; you can prototype this kind of stuff with Photoshop/Gimp layers easily).
    I like image-processing solutions like this because 1. For an end-use you can more easily run the whole thing on a GPU where operations over a whole image are cheap and reducing that an array of numerical results is the expensive part, and 2. You can visually see and tune/debug the dilated image, the dilated-compared image, the dilated-compared-eroded image, and the dilated-compared-eroded-compared image.

    • @ClarityCoders
      @ClarityCoders  3 года назад

      Very good points and great feedback. Thanks for watching and commenting.

  • @fg87fgd
    @fg87fgd 3 года назад

    Couldn't be more clear. Many thanks...

  • @wyatt5984
    @wyatt5984 3 года назад +6

    I love the tutorial; keep up the great work! Heads up, I am coming for your high score ;)

    • @ClarityCoders
      @ClarityCoders  3 года назад +1

      I hope you do! Thanks for watching I appreciate it!

    • @wyatt5984
      @wyatt5984 3 года назад

      Your score has been topped! No template matching was needed since the game uses the exact same pixels in the same locations but still great to know that functionality exists within OpenCV. keep on keepin on.

    • @ClarityCoders
      @ClarityCoders  3 года назад +1

      @@wyatt5984 Yeah I noticed that as well haha! Gives you some flexibility for more complex games though. Nice score!

    • @ClarityCoders
      @ClarityCoders  3 года назад +2

      @@wyatt5984 Our discord is you're into that sort of thing. discord.gg/cAWW5qq

  • @hiperion_1416
    @hiperion_1416 3 года назад +3

    getting game information from memory: 😴😴🤢🤬🤬
    getting game information using opencv: 😎😎🤑🤑🥶🥶

    • @ClarityCoders
      @ClarityCoders  3 года назад +1

      Both can be crazy frustrating haha...

  • @gunnerstone120
    @gunnerstone120 3 года назад +3

    Nice; Solid introductory video! I enjoyed watching. Wish there was a fast & efficient template matching method that worked with a high dimensional image space. I imagine the game you tested in the vid was only 800x600 or something lol. When working with large images I usually have to search a small section or it will take too long to compute.

    • @ClarityCoders
      @ClarityCoders  3 года назад

      For sure I almost always cut down the area where I'm taking the screen shots. Especially if it's a real time thing where time matters. Thanks for watching and commenting I really appreciate it.

    • @SuperMasterDesaster
      @SuperMasterDesaster 3 года назад +3

      You could also try speeding it up by scaling the image down before performing the template matching.

    • @ClarityCoders
      @ClarityCoders  3 года назад

      @@SuperMasterDesaster Yeah I really like this idea as well.

  • @CrynogarTM
    @CrynogarTM 2 месяца назад

    I use IDA Pro to Dominate in Multiplayer Games. In HTML Games I reverse the Server requests and just need a proper parser or memory pattern.

  • @XIAOBAIZHANG-ym8pn
    @XIAOBAIZHANG-ym8pn 7 месяцев назад

    Very good video, can you combine your idea into the online game of chess, and use OPENCV to identify the FEN position code of chess on the web page?

  • @Elislavkat
    @Elislavkat 10 месяцев назад

    amazing. thanks. so much easy class from you

  • @furkanakcakaya9443
    @furkanakcakaya9443 3 года назад +1

    expected to see dominating that online farming game

  • @Aloofang
    @Aloofang 3 года назад

    Thank you for making this video, it really helps me a lot.

    • @ClarityCoders
      @ClarityCoders  3 года назад

      I hope so. Let me know if you have any questions.

  • @Nougat_Noah
    @Nougat_Noah 3 года назад +4

    Nice video but one question. Did you purposefully excactly double their highscore at the end or was that coincidence?

    • @ClarityCoders
      @ClarityCoders  3 года назад +4

      I didn't even know! Good to have eyes like yours on these videos. Thanks for watching Noah.

  • @patrickmueller9658
    @patrickmueller9658 2 года назад

    Liked and subscribed - explained and shown structured and clearly! Thanks!

  • @farmminer4014
    @farmminer4014 3 года назад +3

    Thank you! Very great guide to OpenCV! But how to optimize it to get it to run 100 times faster? How to use multiple CPU cores and GPU with OpenCV?

    • @pianochannel100
      @pianochannel100 3 года назад

      @TridentflayerThe other thing you can attempt to do is vectorize your code very heavily so that you can do all of your calculations in numpy operations. Speaking from miserable experience, that can be far harder than just biting the bullet and doing it in c++

  • @RiddleRations
    @RiddleRations 8 месяцев назад

    Awesome video! Learned a lot!

  • @bartvrhijn
    @bartvrhijn 2 года назад +1

    Jupyter us perfect for a live demonstration 👌

    • @ClarityCoders
      @ClarityCoders  2 года назад

      I agree. I actually caught a lot of heat for using Jupyter haha...

  • @cl00x3r
    @cl00x3r Год назад +1

    about kick ya chop, u dont have to use entire detection system as u did with opencv, wastefull, slow. u can avchieve same result by just sticking to 1 backround pixel with 2 lines of code at max

  • @contantino_mm
    @contantino_mm 3 года назад

    blessed by youtube algo.. found your video and subscribed!

    • @ClarityCoders
      @ClarityCoders  3 года назад +1

      It's actually given me some love this past week. Thanks for watching and commenting.

  • @cancihancelebi3495
    @cancihancelebi3495 7 месяцев назад

    Thank you very much my friend, first of all, I follow the wheat finding code exactly and it doesn't work. Can you send it as a working project rather than a tutorial?

  • @iliqnew
    @iliqnew 3 года назад

    OOOR in order to get rid of the additional rectangles you could just use sets to make get rid of data repetition

  • @Atropin4ik
    @Atropin4ik 2 года назад

    @claritycoders Thanks fo the videos! May you guys comment on how do games (their developers) catch such bots? Asking for the ways around obviously)

  • @deplorablesecuritydevices
    @deplorablesecuritydevices 3 года назад

    Very useful, thank you for sharing!

  • @liambury529
    @liambury529 11 месяцев назад

    Cool video but if you used vs code you wouldn't need 2/3 of your code to be erroneous functions calls that you just need to keep it from crashing.

  • @impzhu3088
    @impzhu3088 3 года назад

    Wow, this is so cool! Thanks for sharing!

    • @ClarityCoders
      @ClarityCoders  3 года назад

      Thanks for the comment more to come stay tuned.

  • @walney2008
    @walney2008 3 года назад

    please your codi, dimensions_left = {
    'left': 164,
    'top': 92,
    'width': 150,
    'height': 250
    }
    dimensions_right = {
    'left': 520,
    'top': 600,
    'width': 150,
    'height': 250
    } , what config positions the screen corret ? what exemple ?

  • @mateussantiago3131
    @mateussantiago3131 2 года назад

    ty cuz ive been having a hard ti getting started.

    • @ClarityCoders
      @ClarityCoders  2 года назад

      Anytime let me know if you have any questions!

  • @peterkim7577
    @peterkim7577 2 года назад +1

    TNice tutorials video is a great introduction to soft soft for beginners. I would Nice tutorialghly recomnd tNice tutorials tutorial to anyone starting out with soft soft.

    • @ClarityCoders
      @ClarityCoders  2 года назад

      Appreciate it! Thanks for the comment.

  • @1996Pinocchio
    @1996Pinocchio 3 года назад +2

    3:29 "inside PAINT"???
    Dude, just hit Shift+WindowsKey+S and cut out the picture you need :->
    Good video tho, really helpful :)

  • @Promptshot
    @Promptshot Год назад

    why is my match when copying and pasting from the haystack img 70-86% match instead of 99??? what am i doing wrong?

  • @4ur3n
    @4ur3n 3 года назад +5

    great job man :D

  • @alonewolf7682
    @alonewolf7682 2 года назад

    Thank You for this valuable video

  • @officialonbekende9785
    @officialonbekende9785 2 года назад

    imshow,imread,and al the rest of the stuff that comes after cv2. isnt working . it says __init__.py isnt found .i reinstalled is 5 times but still nothing

  • @BebebnyaHuTao
    @BebebnyaHuTao Год назад

    This is awesome thanks for the tutorial!
    I just wonder how to implement the code with 5 multiple window (open at the same time)

  • @jeepjr
    @jeepjr 3 года назад

    Teacher, first congratulations for the channel. I need your help, I have a simple image with a range of 5 placements where the quantity is identified, how do I identify the biggest color type red and say where the X,Y is, and if you can help me, and only for create an alert.

  • @timetoplay2927
    @timetoplay2927 8 месяцев назад

    Это работает для статики. Тут зерно имеет конкретные цвета и никак не меняется. Я пробовал этот метод и он не работает для динамических картинок. Например, на экране идет снег, и снежинки закрывают объект, задний фон объекта меняется.

  • @joulesinwatt
    @joulesinwatt 3 года назад +1

    This is a huge inspiration.

  • @NoOne-iu2pq
    @NoOne-iu2pq 3 года назад

    As a way to learn OpenCV - "why not". However Sikuli is already doing all that. And it's Python-based (one of the options).

    • @ClarityCoders
      @ClarityCoders  3 года назад

      I would agree if you just want to quick automate something there are better routes! You can however build on this into full NN that have endless possibilities. Thanks for watching I really appreciate it.

  • @eliebordron5599
    @eliebordron5599 3 года назад

    this seems really really cool; I want to do that on forge of empires . I'll watch this at some point

    • @ClarityCoders
      @ClarityCoders  3 года назад

      Hope you do! Thanks for the comment.

  • @drdca8263
    @drdca8263 3 года назад

    Oh, this might solve a problem I have. There’s some made up alphabet which looks like it was made with a fixed typeface, and I want to transcribe the text in the images into actual text in order to try to decipher it, and I think I know how to extract the characters, but I still need to find how to detect which character they are.
    I can’t use standard OCR because these are a made up alphabet in an Easter egg for a game.

  • @melonman1252
    @melonman1252 3 года назад +1

    Great Video!

    • @ClarityCoders
      @ClarityCoders  3 года назад +1

      Thanks for watching protect that melon.

  • @hellod2831
    @hellod2831 2 года назад

    Great video, very helpful

  • @ProBloggerWorld
    @ProBloggerWorld 3 года назад

    Dude, this is so genius. Thx!

  • @actionkey8042
    @actionkey8042 3 года назад

    ClarityCoders
    -very very awesome

    • @ClarityCoders
      @ClarityCoders  3 года назад

      Thanks I really appreciate the comment.

    • @actionkey8042
      @actionkey8042 3 года назад

      @@ClarityCoders DO MORE AWESOME THINGSS)))

  • @siswanto4045
    @siswanto4045 10 месяцев назад

    I'm imagining, how can I use template matching on GIS software.

  • @tejeshjadhav4172
    @tejeshjadhav4172 3 года назад

    that small insect walking across his screen got me

  • @carlospazuzu
    @carlospazuzu Год назад

    Are you taking screenshots from the whole screen or just the browser content?

  • @4ngeek
    @4ngeek 3 года назад

    I always compared images with mean square root or structural similarity. Template matching seem to be more intuitive

    • @ClarityCoders
      @ClarityCoders  3 года назад

      Probably similar in speed? Thanks for watching / commenting.

  • @vinceangeloespada6927
    @vinceangeloespada6927 3 года назад +1

    Thank you Mac Miller.

  • @thewdead3673
    @thewdead3673 2 года назад

    great video! could you make something like this for a pokemon game walking in a grass and leveling up?

  • @UTJK.
    @UTJK. 3 года назад

    Could this tecnique work to detect parts of a document (for example a rectangle with a text) in order to read what's inside that section of the document? It would be a scanned document so it could arrive with horizontal lines not perfectly aligned due the subtle movements of the paper durinig the passage under the scanner.

    • @Hato1992
      @Hato1992 3 года назад

      I think you can make it much easier. OpenCV can detect rectangles in image. Next, it can detect text (OCR) within those rectangles. If rectangles are not perfectly aligned you can fix perspective of those rects in openCV too.

  • @andrewyoung9290
    @andrewyoung9290 3 года назад +2

    This is a great tutorial - thanks! Could you also do one explaining the kick ya chop script you have in your git hub? Also I tried to use the kick ya chop script but had to increase the sleep time to around 0.2 otherwise it wouldn't work. This is even after I tried reducing the region to search in. What gives? Do I need a faster computer or something?

    • @ClarityCoders
      @ClarityCoders  3 года назад +1

      Yeah it might just be a difference in processing speed. I'll try to get some videos out explaining the code more in depth.

  • @hafizhnugrahav0113
    @hafizhnugrahav0113 3 года назад

    woah you jump from 2k subs to 7k in 5 days, congrats

  • @jaimetheone9150
    @jaimetheone9150 2 года назад

    This works perfectly on VSCode, but as soon as I turn it into an exe with pyinstaller it does nothing.

  • @jeanregis9030
    @jeanregis9030 2 года назад

    Great video thank you!

  • @robertwoodruff8491
    @robertwoodruff8491 3 года назад

    This is AWESOME and it has been extremely helpful to me.
    There is one thing I'm trying to figure out. Let's say I grab an image and I know I want to look for one "needle" in the lower half of the image and a second in the upper half of the image and I want to know the relationship of the matches to each other.
    Now one way I could do this is grab two different regions two images. Do the matches, and then use some math to figure out their relationship to each other.
    But, what would be really convenient is if I can just look for the matches I need to in the lower half the image and get, multiple matches and then look for the other needle in the upper half and get multiple matches and already have the x and y coordinates for the overall image without having to translate them.
    If it can't be done, it's easy enough to add y offset to the coordinates I get out. But I was wondering.

    • @ClarityCoders
      @ClarityCoders  3 года назад

      You mean you want to save time by only looking in the correct regions of the images while searching? You could use slicing to accomplish this task. Google python slicing.

  • @KiraIsGod
    @KiraIsGod 3 года назад

    Pretty nice! Found this on my recommended. Subbed :)

    • @ClarityCoders
      @ClarityCoders  3 года назад

      Thanks for the sub / comment means a lot.

  • @HelloWorld-vm9gz
    @HelloWorld-vm9gz 3 года назад

    Can i work with multiple models of an NPC (different color clothes, but similar image) in 3d? Like multiple images, side, front, back?

    • @ClarityCoders
      @ClarityCoders  3 года назад

      Might needs something a little more flexible like a neural network.

  • @ZirbertEruj
    @ZirbertEruj 3 года назад +1

    Amezing tutorial, subscrubed!

    • @ClarityCoders
      @ClarityCoders  3 года назад

      Thank you! Thanks for watching / commenting.

  • @MrMatirafi
    @MrMatirafi Год назад

    Hi i am beginner, i am preparing script for a similar game but the question is can i run script like this for multiple game windows lets say arranged in 3x3 matirx (just like tic tac toe) on desktop and would it work or do i need to implement something more?

  • @AbdelrahmanRashed
    @AbdelrahmanRashed 3 года назад

    I'm pretty sure there are a lot of better and easier ways to prevent duplicate/overlapping rectangles, but grouping them is way more taxing and complicated than just filtering them out.

    • @ClarityCoders
      @ClarityCoders  3 года назад +1

      Very good points. I'll look into the options and improve the instruction next time. Thanks for watching and commenting.

  • @jean-marctrutna4098
    @jean-marctrutna4098 2 года назад

    Is it possible to move the mouse to the location of the identified object on the screen instead of a pre-set point?

  • @admin2695
    @admin2695 2 года назад

    In The setup thank you so much!

  • @walidyoucefkahla6120
    @walidyoucefkahla6120 2 года назад

    bro can you write it as a scipte cause i tryed and it doesn't work like yours the rectongel doesnt showed on the the colored image

  • @connorbrennan1865
    @connorbrennan1865 3 года назад

    A better way to deal with multiple matches corresponding to a single item is to use a local maximum finder. scikit-image's peak_local_max is one such possibility.

  • @KiwiRedstone
    @KiwiRedstone 3 года назад

    How to take screenshot and use it as a variable instead of writing it to file and reading it from the file. The issue I have is that first, I'm afraid that my harddrive age won't last that long with this method and second, it is faster

    • @ClarityCoders
      @ClarityCoders  3 года назад

      Check out the code on the github for kick ya chop. I do exactly that! github.com/ClarityCoders/ComputerVision-OpenCV/blob/master/Lesson3-TemplateMatching/PlayGame.py

  • @a_pullin
    @a_pullin 3 года назад

    Funny thing is, really early Ultima Online "autopilots" used image matching like this. Might have even predated OpenCV ...

  • @nicolassuarez2933
    @nicolassuarez2933 5 месяцев назад

    Outstanding!

  • @jackrdye
    @jackrdye 3 года назад

    2nd year cs student - these videos are awesome keep it up!!

  • @jakefreise7601
    @jakefreise7601 3 года назад

    Instead of trying to group rectangles together, why not just find the local maximas of the correlation values?