Skip to content

A computer vision bot made with OpenCV, OCR and ADB.

Notifications You must be signed in to change notification settings

NomadCHK/pokemon-pocket-bot

 
 

Repository files navigation


Markdownify
Pokemon Pocket Bot ⚔️

A computer vision bot made with OpenCV and ADB.

Python

Description:

The Pokemon Pocket Bot is an automation tool designed to streamline gameplay within the "Pokemon Pocket" game. Tailored specifically for LDPlayer, an Android emulator, this bot simplifies repetitive tasks by automating gameplay actions, allowing users to focus on strategic decisions and progression.

Animation

Usage:

  • 1. Start LDPlayerEmulator
  • 2. Enable ADB connection Open Local connection
  • 3. Choose the resolution to be 1600x900 (dpi 240)
  • 4. Install the requirements: pip install -r requirements.txt
  • 5. Start the bot: python app.py
  • 6. Start Pokemon Pocket (the game must be in english)
  • 7. Choose the path to the emulator You have to choose the main folder of the emulator (in the LDPlayer case would be LDPlayer/LDPlayer9)
  • 8. Start botting You can choose between two modes, Auto Concede to farm fast matches and Start Bot, still WIP.

LDPlayer Settings:

Markdownify
Markdownify

Deck Configuration

One of the best features of this bot is its flexibility to use any custom deck—no specific cards are required! You can modify the deck settings by editing deck.py. Each card in the deck is defined in a dictionary format, with various attributes describing its properties. Here’s how each attribute works:

Card Format

Each card entry in deck.py has the following structure:

"rattata": {
    "level": 0,
    "energies": 1,
    "evolves_from": None,
    "can_evolve": True,
    "item_card": False
},

Attribute Explanations:

  • level: This indicates the evolution stage of the Pokemon:

    • 0: Basic Pokemon, the starting stage.
    • 1: Stage 1 Pokemon, evolves from a basic Pokemon.
    • 2: Stage 2 Pokemon, evolves from a Stage 1 Pokemon.
  • energies: The number of energies needed for this Pokemon to perform an attack. Set this to the minimum number of energies typically required to use its main move.

  • evolves_from: If this Pokemon evolves from another, set this to the exact name of its pre-evolution (e.g., "evolves_from": "rattata" for Raticate). For basic Pokemon, set this to None.

  • can_evolve: A boolean value (True or False) indicating if this card is capable of evolving into a higher stage. Set this to True if there is a corresponding evolution in your deck.

  • item_card: Set to True if this is a Trainer card. Trainer cards are treated as single-use items in the bot's logic and can be played directly onto the field.

By modifying the entries in deck.py to match your preferred cards, you can fully customize the bot’s deck to fit your strategy. Just be sure each Pokemon and Trainer card entry is formatted correctly to avoid any errors!

Adding New Cards

If you want to use cards that aren’t currently available in the images/cards folder, you’ll need to add them yourself by capturing a screenshot. You can use the screenshot function from the bot app to take a capture at 100% resolution. After capturing, crop the image precisely to the card area and save it in the images/cards folder with the corresponding name (check the ones already created). This will allow the bot to recognize and use these new cards in your custom deck.

Key Features:

  • Emulator Path Selection: Users can easily specify the path to their LDPlayer installation within the bot's interface, facilitating seamless integration with the emulator.

  • Play Random Matches: With automated matches functionality, the bot plays random matches to farm store tickets and 15 exp.

  • Concede Random Matches: With automated matches functionality, the bot concedes random matches to farm store tickets.

Benefits:

  • Efficiency: By automating repetitive tasks such as lamp rolling and dungeon exploration, the bot significantly reduces the time and effort required for gameplay, allowing players to achieve their goals more efficiently.

  • Optimization: Through intelligent equipment management and strategic decision-making, the bot maximizes the effectiveness of in-game resources, enhancing the player's overall gaming experience.

  • Convenience: The user-friendly interface and seamless integration with LDPlayer make the bot easy to set up and operate, providing players with a convenient solution for enhancing their gameplay experience.

Roadmap

These are the key milestones for the current and future versions of the bot:

  • Search for the time limit icon
  • Determine if it’s your turn or the enemy turn
  • Analyze hand cards
  • Analyze cards on the field
  • Play basic Pokemon on the main field
  • Play basic Pokemon on the bench fields
  • Attach energy to the main Pokemon
  • Evolve the main Pokemon
  • Use Trainer cards
  • Attack with the main Pokemon
  • End turn
  • Run in a continuous 24/7 loop
  • Track energy count for each Pokemon
  • Enable evolution of bench Pokemon
  • Inspect the enemy’s main Pokemon
  • Check health of the enemy’s main Pokemon
  • Track and calculate attack power for each Pokemon
  • Monitor health of the main Pokemon
  • Implement a priority queue to select the optimal Pokemon for play
  • Read decks from txt files
  • Support multiple languages

This checklist can be updated over time as more features are added and improved, ensuring steady progress toward full automation and strategic gameplay.

Target Audience:

  • Gamers: Pokemon Pocket players seeking to streamline gameplay and optimize resource management.

  • LDPlayer Users: Users of the LDPlayer Android emulator looking to enhance their gaming experience through automation.

Overall, the Pokemon Pocket Bot offers a powerful yet user-friendly solution for automating gameplay tasks within the Pokemon Pocket game, providing players with greater efficiency, optimization, and convenience in their gaming journey.

About

A computer vision bot made with OpenCV, OCR and ADB.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%