Better mask combination

conquest_develop
bobloy 4 years ago
parent e2e5477661
commit f0d33f0354

@ -29,7 +29,7 @@ class Conquest(commands.Cog):
super().__init__() super().__init__()
self.bot = bot self.bot = bot
self.config = Config.get_conf( self.config = Config.get_conf(
self, identifier=67111110113117101115116, force_registration=True self, identifier=67_111_110_113_117_101_115_116, force_registration=True
) )
default_guild = {} default_guild = {}
@ -352,7 +352,7 @@ class Conquest(commands.Cog):
"Failed to combine masks, try the command again or check log for errors" "Failed to combine masks, try the command again or check log for errors"
) )
return return
await ctx.tick() await ctx.maybe_send_embed(f"Combined masks into mask # {result}")
@commands.group() @commands.group()
async def conquest(self, ctx: commands.Context): async def conquest(self, ctx: commands.Context):
@ -459,7 +459,7 @@ class Conquest(commands.Cog):
await self._get_current_map_path() / f"current.{self.ext}", x, y, zoom await self._get_current_map_path() / f"current.{self.ext}", x, y, zoom
) )
await ctx.send(file=discord.File(fp=zoomed_path, filename=f"current_zoomed.{self.ext}",)) await ctx.send(file=discord.File(fp=zoomed_path, filename=f"current_zoomed.{self.ext}"))
@conquest_set.command(name="save") @conquest_set.command(name="save")
async def _conquest_set_save(self, ctx: commands.Context, *, save_name): async def _conquest_set_save(self, ctx: commands.Context, *, save_name):
@ -597,7 +597,9 @@ class Conquest(commands.Cog):
) )
await self._send_maybe_zoomed_map( await self._send_maybe_zoomed_map(
ctx, current_map_path / f"current_numbered.{self.ext}", f"current_numbered.{self.ext}", ctx,
current_map_path / f"current_numbered.{self.ext}",
f"current_numbered.{self.ext}",
) )
@conquest.command(name="multitake") @conquest.command(name="multitake")

@ -176,7 +176,7 @@ class ConquestMap:
"name": self.name, "name": self.name,
"custom": self.custom, "custom": self.custom,
"region_max": self.region_max, "region_max": self.region_max,
"regions": {num: r.get_json() for num, r in self.regions.items()} "regions": {num: r.get_json() for num, r in self.regions.items()},
} }
with self.data_path().open("w+") as dp: with self.data_path().open("w+") as dp:
json.dump(to_save, dp, sort_keys=True, indent=4) json.dump(to_save, dp, sort_keys=True, indent=4)
@ -210,6 +210,7 @@ class ConquestMap:
self.region_max = len(regions) + 1 self.region_max = len(regions) + 1
await self.save_data() await self.save_data()
return regions
async def create_number_mask(self): async def create_number_mask(self):
regioner = Regioner(filename="blank.png", filepath=self.path) regioner = Regioner(filename="blank.png", filepath=self.path)
@ -223,14 +224,19 @@ class ConquestMap:
if not lowest: if not lowest:
return lowest return lowest
try:
elim_regions = [self.regions[n] for n in eliminated] elim_regions = [self.regions[n] for n in eliminated]
lowest_region = self.regions[lowest] lowest_region = self.regions[lowest]
except KeyError:
return False
# points = [self.mm["regions"][f"{n}"]["center"] for n in mask_list] # points = [self.mm["regions"][f"{n}"]["center"] for n in mask_list]
# #
# points = [(r.center, r.weight) for r in elim_regions] # points = [(r.center, r.weight) for r in elim_regions]
weighted_points = [r.center for r in elim_regions for _ in range(r.weight)] weighted_points = [r.center for r in elim_regions for _ in range(r.weight)] + [
lowest_region.center for _ in range(lowest_region.weight)
]
lowest_region.center = get_center(weighted_points) lowest_region.center = get_center(weighted_points)
@ -245,7 +251,7 @@ class ConquestMap:
await self.save_data() await self.save_data()
return True return lowest
def _img_combine_masks(self, mask_list: List[int]): def _img_combine_masks(self, mask_list: List[int]):
if not mask_list: if not mask_list:
@ -291,18 +297,18 @@ class ConquestMap:
) )
current_map = await composite_regions( current_map = await composite_regions(
current_map, current_map,
regions[fourth: fourth * 2], regions[fourth : fourth * 2],
ImageColor.getrgb("green"), ImageColor.getrgb("green"),
self.masks_path(), self.masks_path(),
) )
current_map = await composite_regions( current_map = await composite_regions(
current_map, current_map,
regions[fourth * 2: fourth * 3], regions[fourth * 2 : fourth * 3],
ImageColor.getrgb("blue"), ImageColor.getrgb("blue"),
self.masks_path(), self.masks_path(),
) )
current_map = await composite_regions( current_map = await composite_regions(
current_map, regions[fourth * 3:], ImageColor.getrgb("yellow"), self.masks_path() current_map, regions[fourth * 3 :], ImageColor.getrgb("yellow"), self.masks_path()
) )
current_numbered_img = await self.get_numbered(current_map) current_numbered_img = await self.get_numbered(current_map)
@ -345,11 +351,7 @@ class Region:
self.data = kwargs self.data = kwargs
def get_json(self): def get_json(self):
return { return {"center": self.center, "weight": self.weight, "data": self.data.copy()}
"center": self.center,
"weight": self.weight,
"data": self.data.copy()
}
class Regioner: class Regioner:
@ -404,9 +406,7 @@ class Regioner:
mask = mask.convert("L") mask = mask.convert("L")
mask.save(masks_path / f"{mask_count}.png", "PNG") mask.save(masks_path / f"{mask_count}.png", "PNG")
regions[mask_count] = Region( regions[mask_count] = Region(center=get_center(filled), weight=len(filled))
center=get_center(filled), weight=len(filled)
)
already_processed.update(filled) already_processed.update(filled)
@ -431,6 +431,6 @@ class Regioner:
w1, h1 = region.center w1, h1 = region.center
w2, h2 = fnt.getsize(text) w2, h2 = fnt.getsize(text)
d.text((w1-(w2/2), h1-(h2/2)), text, font=fnt, fill=0) d.text((w1 - (w2 / 2), h1 - (h2 / 2)), text, font=fnt, fill=0)
number_img.save(self.filepath / f"numbers.png", "PNG") number_img.save(self.filepath / f"numbers.png", "PNG")
return True return True

Loading…
Cancel
Save