detail_huilima3.py 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383
  1. """
  2. 步骤:
  3. 1、整理需要处理的款号图-输出款号图文件夹
  4. 2、整理所有相关的图片作为素材图
  5. 3、按要求进行拼接
  6. """
  7. import os
  8. from PIL import ImageFont
  9. import sys
  10. import settings
  11. # from module.view_control.generate_goods_no_detail_pic.detail_generate_base import DetailBase
  12. # from module.view_control.generate_goods_no_detail_pic.pic_deal import PictureProcessing
  13. is_test_plugins = False
  14. try:
  15. is_test_plugins = settings.is_test_plugins
  16. except:
  17. is_test_plugins = False
  18. if is_test_plugins:
  19. from custom_plugins.plugins_mode.detail_generate_base import DetailBase
  20. from custom_plugins.plugins_mode.pic_deal import PictureProcessing
  21. else:
  22. from plugins_mode.detail_generate_base import DetailBase
  23. from plugins_mode.pic_deal import PictureProcessing
  24. plugins_name = "详情模板"
  25. company_name_list = ["全部"]
  26. template_name = "huilima-3"
  27. # 运动鞋详情页
  28. class DetailPicGet(DetailBase):
  29. need_view = ["俯视", "侧视", "后跟", "鞋底", "内里"]
  30. root = r"{}\resources\detail_temp\huilima\3".format(os.getcwd())
  31. def __init__(self, goods_no, goods_no_value: dict, out_put_dir, windows=None, test=False, excel_data=None,
  32. assigned_page_list=None, **kwargs):
  33. super().__init__(goods_no, goods_no_value, out_put_dir, windows=windows, excel_data=excel_data,
  34. assigned_page_list=assigned_page_list)
  35. self.template_name = template_name
  36. self.root = r"{}\resources\detail_temp\huilima\3".format(os.getcwd())
  37. print("run huilima-3 ")
  38. self.base_bg_color = (255, 255, 255)
  39. self.deal_pic_func_list = [
  40. self.deal_pic_1,
  41. self.deal_pic_2,
  42. self.deal_pic_2_2,
  43. self.deal_pic_2_3,
  44. self.deal_pic_3,
  45. self.deal_pic_4,
  46. self.deal_pic_5,
  47. ]
  48. if test:
  49. self.run_test()
  50. else:
  51. self.run_all()
  52. def run_test(self):
  53. detailed_images = []
  54. detailed_images.append(self.deal_pic_1())
  55. detailed_images.append(self.deal_pic_2())
  56. detailed_images.append(self.deal_pic_3())
  57. detailed_images.append(self.deal_pic_4())
  58. detailed_images.append(self.deal_pic_5())
  59. img = self.add_pic(detailed_images)
  60. if img:
  61. self.create_folder(r"{}/{}".format(self.out_put_dir, template_name))
  62. img.save(r"{}/{}/{}.jpg".format(self.out_put_dir, template_name, self.goods_no, format="JPEG"))
  63. img.show()
  64. # 使用动态拼接的方式进行实现
  65. def deal_pic_1_other(self):
  66. pp_bg = PictureProcessing(r"{}\2.jpg".format(self.root))
  67. goods_art_no_list = list(self.data.keys())
  68. # 粘贴多色图,步骤
  69. # 创建一个白色底大画布,循环粘贴鞋子,先粘贴所有的阴影图,再粘贴透明图,记录最大边。
  70. # 剪裁再粘贴到背景上
  71. pp_jpg_1_list = []
  72. pp_png_1_list = []
  73. for goods_art_no_dict in self.goods_no_value["货号资料"]:
  74. color_name = goods_art_no_dict["颜色名称"]
  75. goods_art_no = goods_art_no_dict["货号"]
  76. pp_jpg_1, pp_png_1 = self.image_one_pic(return_orign=True,
  77. goods_art_no=goods_art_no,
  78. name="俯视",
  79. )
  80. pp_jpg_1_list.append(pp_jpg_1)
  81. pp_png_1_list.append(pp_png_1)
  82. x, y = 0, 0
  83. pp_bg_jpg = PictureProcessing("RGB", (1600, 1600), (255, 255, 255))
  84. if len(pp_jpg_1_list) == 1:
  85. _resize_value = 1100
  86. else:
  87. _resize_value = 900
  88. for index, pp_jpg in enumerate(pp_jpg_1_list):
  89. pp_jpg = pp_jpg.resize(value=_resize_value + 100 * index)
  90. pp_bg_jpg = pp_bg_jpg.to_overlay_pic_advance(top_img=pp_jpg,
  91. value=(x, y))
  92. x += 180
  93. y += 60
  94. x, y = 0, 0
  95. pp_bg_png = PictureProcessing("RGBA", (1600, 1600), (255, 255, 255, 0))
  96. for index, pp_png in enumerate(pp_png_1_list):
  97. pp_png = pp_png.resize(value=_resize_value + 100 * index)
  98. pp_bg_png = pp_bg_png.paste_img(top_img=pp_png,
  99. value=(x, y))
  100. x += 180
  101. y += 60
  102. min_bbox = pp_bg_png.getbbox()
  103. min_bbox = PictureProcessing().expand_bbox(min_bbox)
  104. pp_bg_jpg = pp_bg_jpg.crop(bbox=min_bbox)
  105. pp_bg_png = pp_bg_png.crop(bbox=min_bbox)
  106. pp_bg = pp_bg.to_overlay_pic_advance(top_img=pp_bg_jpg, top_png_img=pp_bg_png, base="cc")
  107. return pp_bg
  108. # 斜视图展示 多色进行拼接
  109. def deal_pic_1(self):
  110. detailed_images = []
  111. detailed_images.append(PictureProcessing(r"{}\1.jpg".format(self.root)))
  112. goods_art_no_list = list(self.data.keys())
  113. # 粘贴多色图,步骤
  114. # 创建一个白色底大画布,循环粘贴鞋子,先粘贴所有的阴影图,再粘贴透明图,记录最大边。
  115. # 剪裁再粘贴到背景上
  116. pp_jpg, pp_png = self.image_one_pic(return_orign=True,
  117. goods_art_no=goods_art_no_list[0],
  118. name="组合",
  119. )
  120. if pp_jpg:
  121. pp_bg = PictureProcessing(r"{}\2.jpg".format(self.root))
  122. pp_jpg = pp_jpg.resize(value=1312)
  123. pp_png = pp_png.resize(value=1312)
  124. pp_bg = pp_bg.to_overlay_pic_advance(top_img=pp_jpg, top_png_img=pp_png, base="cc")
  125. else:
  126. pp_bg = self.deal_pic_1_other()
  127. detailed_images.append(pp_bg)
  128. pp_bg_2 = PictureProcessing(r"{}\3.jpg".format(self.root))
  129. font_1 = ImageFont.truetype(r"resources\ttf\puhui\Regular.ttf", 60) # 颜色名称
  130. text = self.get_text_value("标题")
  131. if text:
  132. _pp = PictureProcessing().get_text_image_advanced(
  133. font=font_1,
  134. text=text,
  135. fill=(255, 255, 255),
  136. return_mode="min_image",
  137. )
  138. pp_bg_2 = pp_bg_2.paste_img(top_img=_pp, value=(0, 362), base="nc")
  139. detailed_images.append(pp_bg_2)
  140. return PictureProcessing(im=self.add_pic(detailed_images))
  141. # 展示基础信息
  142. def deal_pic_2(self):
  143. detailed_images = []
  144. detailed_images.append(PictureProcessing(r"{}\4.jpg".format(self.root)))
  145. pp_bg_1 = PictureProcessing(r"{}\5.jpg".format(self.root))
  146. # 粘贴侧视图
  147. goods_art_no_list = list(self.data.keys())
  148. pp_jpg_1, pp_png_1 = self.image_one_pic(return_orign=True,
  149. goods_art_no=goods_art_no_list[0],
  150. name="侧视",
  151. )
  152. pp_jpg_1 = pp_jpg_1.resize(value=1312)
  153. pp_png_1 = pp_png_1.resize(value=1312)
  154. pp_bg_1 = pp_bg_1.to_overlay_pic_advance(top_img=pp_jpg_1, top_png_img=pp_png_1, base="cc")
  155. # pp_bg_1.show()
  156. detailed_images.append(pp_bg_1)
  157. # 介绍卖点
  158. font_1 = ImageFont.truetype(r"resources\ttf\puhui\Medium.ttf", 60) # 颜色名称
  159. text_list = [
  160. {"text": "卖点1标题", "pos": (0, 58)},
  161. {"text": "卖点2标题", "pos": (0, 283)},
  162. {"text": "卖点3标题", "pos": (0, 505)},
  163. ]
  164. pp_bg_2 = PictureProcessing(r"{}\6.jpg".format(self.root))
  165. for text_data in text_list:
  166. text = self.get_text_value(text_data["text"])
  167. if text:
  168. _pp = PictureProcessing().get_text_image_advanced(
  169. font=font_1,
  170. text=text,
  171. fill=(0, 0, 0),
  172. return_mode="min_image",
  173. )
  174. pp_bg_2 = pp_bg_2.paste_img(top_img=_pp, value=text_data["pos"], base="nc")
  175. detailed_images.append(pp_bg_2)
  176. return PictureProcessing(im=self.add_pic(detailed_images))
  177. #模特图
  178. def deal_pic_2_2(self):
  179. if self.get_text_value("模特图"):
  180. mote_img = PictureProcessing(self.get_text_value("模特图"))
  181. mote_img = mote_img.resize(value=1600)
  182. bg_img = PictureProcessing("RGB", (mote_img.width, mote_img.height), (255,255,255))
  183. bg_img = bg_img.paste_img(top_img=mote_img,base="nc", value=(0, 0))
  184. return bg_img
  185. else:
  186. return
  187. #场景图
  188. def deal_pic_2_3(self):
  189. if self.get_text_value("场景图"):
  190. mote_img = PictureProcessing(self.get_text_value("场景图"))
  191. mote_img = mote_img.resize(value=1600)
  192. bg_img = PictureProcessing("RGB", (mote_img.width, mote_img.height), (255,255,255))
  193. bg_img = bg_img.paste_img(top_img=mote_img,base="nc", value=(0, 0))
  194. return bg_img
  195. else:
  196. return
  197. # 细节展示
  198. def deal_pic_3(self):
  199. detailed_images = []
  200. goods_art_no_list = list(self.data.keys())
  201. # 展示鞋面材质 粘贴内里顶视图
  202. detailed_images.append(PictureProcessing(r"{}\7.jpg".format(self.root)))
  203. _, pp_png_1 = self.image_one_pic(return_orign=True,
  204. goods_art_no=goods_art_no_list[0],
  205. name="内里",
  206. )
  207. pp_png_1: PictureProcessing
  208. pp_png_1 = pp_png_1.resize(value=2254)
  209. pp_png_1 = pp_png_1.transpose(mode="left_right")
  210. pp_png_1 = pp_png_1.rotate_advance(doge=-30)
  211. pp_bg_1 = PictureProcessing(r"{}\8.jpg".format(self.root))
  212. pp_bg_1 = pp_bg_1.paste_img(top_img=pp_png_1, value=(50, 50))
  213. detailed_images.append(pp_bg_1)
  214. detailed_images.append(PictureProcessing(r"{}\9.jpg".format(self.root)))
  215. # 展示后跟
  216. _, pp_png_2 = self.image_one_pic(return_orign=True,
  217. goods_art_no=goods_art_no_list[0],
  218. name="侧视",
  219. )
  220. pp_png_2: PictureProcessing
  221. pp_png_2 = pp_png_2.resize(value=2116)
  222. # pp_png_1 = pp_png_1.transpose(mode="left_right")
  223. pp_png_2 = pp_png_2.rotate_advance(doge=30)
  224. pp_bg_2 = PictureProcessing(r"{}\10.jpg".format(self.root))
  225. pp_bg_2 = pp_bg_2.paste_img(top_img=pp_png_2, value=(100, 80), base="ne")
  226. detailed_images.append(pp_bg_2)
  227. detailed_images.append(PictureProcessing(r"{}\11.jpg".format(self.root)))
  228. # 展示鞋头
  229. _, pp_png_3 = self.image_one_pic(return_orign=True,
  230. goods_art_no=goods_art_no_list[0],
  231. name="侧视",
  232. )
  233. pp_png_3: PictureProcessing
  234. pp_png_3 = pp_png_3.resize(value=2116)
  235. # pp_png_1 = pp_png_1.transpose(mode="left_right")
  236. pp_png_3 = pp_png_3.rotate_advance(doge=30)
  237. pp_bg_3 = PictureProcessing(r"{}\12.jpg".format(self.root))
  238. pp_bg_3 = pp_bg_3.paste_img(top_img=pp_png_3, value=(294, 125), base="sw")
  239. detailed_images.append(pp_bg_3)
  240. detailed_images.append(PictureProcessing(r"{}\13.jpg".format(self.root)))
  241. # 展示鞋垫
  242. _, pp_png_4 = self.image_one_pic(return_orign=True,
  243. goods_art_no=goods_art_no_list[0],
  244. name="内里",
  245. )
  246. pp_png_4: PictureProcessing
  247. pp_png_4 = pp_png_4.resize(value=2300)
  248. pp_png_4 = pp_png_4.transpose(mode="left_right")
  249. pp_png_4 = pp_png_4.rotate_advance(doge=30)
  250. pp_bg_4 = PictureProcessing(r"{}\14.jpg".format(self.root))
  251. pp_bg_4 = pp_bg_4.paste_img(top_img=pp_png_4, value=(220, 89), base="ne")
  252. detailed_images.append(pp_bg_4)
  253. detailed_images.append(PictureProcessing(r"{}\15.jpg".format(self.root)))
  254. # raise 1
  255. return PictureProcessing(im=self.add_pic(detailed_images))
  256. # 展示产品信息和颜色图
  257. def deal_pic_4(self):
  258. detailed_images = []
  259. detailed_images.append(PictureProcessing(r"{}\16.jpg".format(self.root)))
  260. goods_art_no_list = list(self.data.keys())
  261. font_1 = ImageFont.truetype(r"resources\ttf\puhui\Regular.ttf", 44) # 颜色名称
  262. view_data_list = ["俯视", "内里", "后跟", "鞋底"]
  263. for goods_art_no_dict in self.goods_no_value["货号资料"]:
  264. color_name = goods_art_no_dict["颜色名称"]
  265. goods_art_no = goods_art_no_dict["货号"]
  266. pp_bg_2 = PictureProcessing(r"{}\17.jpg".format(self.root))
  267. # ==================
  268. text_list = [
  269. {"text": "商品货号", "pos": (83, 1137)},
  270. ]
  271. for text_data in text_list:
  272. text = self.get_text_value(text_data["text"])
  273. if text:
  274. _pp = PictureProcessing().get_text_image_advanced(
  275. font=font_1,
  276. text=text,
  277. fill=(136, 136, 136),
  278. return_mode="min_image",
  279. )
  280. pp_bg_2 = pp_bg_2.paste_img(top_img=_pp, value=text_data["pos"])
  281. # ===================
  282. for view_name in view_data_list:
  283. pp_jpg, pp_png = self.image_one_pic(return_orign=True,
  284. goods_art_no=goods_art_no,
  285. name=view_name,
  286. )
  287. pp_jpg: PictureProcessing
  288. pp_png: PictureProcessing
  289. if view_name == "俯视":
  290. resize_value = 723
  291. value = (418, 735)
  292. if view_name == "内里":
  293. resize_value = 512
  294. value = (1243, 273)
  295. if view_name == "后跟":
  296. pp_jpg = pp_jpg.resize(value=500)
  297. pp_png = pp_png.resize(value=500)
  298. pp_jpg, pp_png = self.copy_view(pp_jpg, pp_png)
  299. resize_value = 469
  300. value = (1243, 681)
  301. if view_name == "鞋底":
  302. resize_value = 512
  303. value = (1243, 1111)
  304. pp_jpg = pp_jpg.resize(value=resize_value)
  305. pp_png = pp_png.resize(value=resize_value)
  306. value = (value[0] - pp_jpg.width / 2, value[1] - pp_jpg.height / 2)
  307. pp_bg_2 = pp_bg_2.to_overlay_pic_advance(top_img=pp_jpg, top_png_img=pp_png, base="nw", value=value)
  308. detailed_images.append(pp_bg_2)
  309. return PictureProcessing(im=self.add_pic(detailed_images))
  310. # 添加注意事项
  311. def deal_pic_5(self):
  312. detailed_images = []
  313. detailed_images.append(PictureProcessing(r"{}\19.jpg".format(self.root)))
  314. detailed_images.append(PictureProcessing(r"{}\20.jpg".format(self.root)))
  315. return PictureProcessing(im=self.add_pic(detailed_images))
  316. def copy_view(self, pp_jpg: PictureProcessing, pp_png: PictureProcessing):
  317. pp_bg_jpg = PictureProcessing("RGB", (1600, 1600), (255, 255, 255))
  318. pp_bg_png = PictureProcessing("RGBA", (1600, 1600), (255, 255, 255, 0))
  319. pp_jpg_1_list = [pp_jpg, pp_jpg]
  320. pp_png_1_list = [pp_png, pp_png]
  321. x, y = 0, 0
  322. for index, pp_jpg in enumerate(pp_jpg_1_list):
  323. pp_bg_jpg = pp_bg_jpg.to_overlay_pic_advance(top_img=pp_jpg,
  324. value=(x, y))
  325. x += pp_jpg.width - 20
  326. x, y = 0, 0
  327. for index, pp_png in enumerate(pp_png_1_list):
  328. pp_bg_png = pp_bg_png.paste_img(top_img=pp_png,
  329. value=(x, y))
  330. x += pp_jpg.width - 20
  331. min_bbox = pp_bg_png.getbbox()
  332. min_bbox = PictureProcessing().expand_bbox(min_bbox, value=50)
  333. pp_bg_jpg = pp_bg_jpg.crop(bbox=min_bbox)
  334. pp_bg_png = pp_bg_png.crop(bbox=min_bbox)
  335. return pp_bg_jpg, pp_bg_png