main.py 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. #!/usr/bin/python
  2. # -*- coding:utf-8 -*-
  3. import epd4in2b
  4. import time
  5. from PIL import Image,ImageDraw,ImageFont
  6. import traceback
  7. try:
  8. epd = epd4in2b.EPD()
  9. epd.init()
  10. print("Clear...")
  11. epd.Clear(0xFF)
  12. # Drawing on the Horizontal image
  13. HBlackimage = Image.new('1', (epd4in2b.EPD_WIDTH, epd4in2b.EPD_HEIGHT), 255) # 298*126
  14. HRedimage = Image.new('1', (epd4in2b.EPD_WIDTH, epd4in2b.EPD_HEIGHT), 255) # 298*126
  15. # Horizontal
  16. print("Drawing")
  17. drawblack = ImageDraw.Draw(HBlackimage)
  18. drawred = ImageDraw.Draw(HRedimage)
  19. font24 = ImageFont.truetype('/usr/share/fonts/truetype/wqy/wqy-microhei.ttc', 24)
  20. drawblack.text((10, 0), 'hello world', font = font24, fill = 0)
  21. drawblack.text((10, 20), '4.2inch e-Paper', font = font24, fill = 0)
  22. drawblack.text((150, 0), u'微雪电子', font = font24, fill = 0)
  23. drawblack.line((20, 50, 70, 100), fill = 0)
  24. drawblack.line((70, 50, 20, 100), fill = 0)
  25. drawblack.rectangle((20, 50, 70, 100), outline = 0)
  26. drawred.line((165, 50, 165, 100), fill = 0)
  27. drawred.line((140, 75, 190, 75), fill = 0)
  28. drawred.arc((140, 50, 190, 100), 0, 360, fill = 0)
  29. drawred.rectangle((80, 50, 130, 100), fill = 0)
  30. drawred.chord((200, 50, 250, 100), 0, 360, fill = 0)
  31. epd.display(epd.getbuffer(HBlackimage), epd.getbuffer(HRedimage))
  32. time.sleep(2)
  33. # Drawing on the Vertical image
  34. LBlackimage = Image.new('1', (epd4in2b.EPD_HEIGHT, epd4in2b.EPD_WIDTH), 255) # 126*298
  35. LRedimage = Image.new('1', (epd4in2b.EPD_HEIGHT, epd4in2b.EPD_WIDTH), 255) # 126*298
  36. # Vertical
  37. drawblack = ImageDraw.Draw(LBlackimage)
  38. drawred = ImageDraw.Draw(LRedimage)
  39. font18 = ImageFont.truetype('/usr/share/fonts/truetype/wqy/wqy-microhei.ttc', 18)
  40. drawblack.text((2, 0), 'hello world', font = font18, fill = 0)
  41. drawblack.text((2, 20), '4.2inch epd', font = font18, fill = 0)
  42. drawblack.text((20, 50), u'微雪电子', font = font18, fill = 0)
  43. drawblack.line((10, 90, 60, 140), fill = 0)
  44. drawblack.line((60, 90, 10, 140), fill = 0)
  45. drawblack.rectangle((10, 90, 60, 140), outline = 0)
  46. drawred.line((95, 90, 95, 140), fill = 0)
  47. drawred.line((70, 115, 120, 115), fill = 0)
  48. drawred.arc((70, 90, 120, 140), 0, 360, fill = 0)
  49. drawred.rectangle((10, 150, 60, 200), fill = 0)
  50. drawred.chord((70, 150, 120, 200), 0, 360, fill = 0)
  51. epd.display(epd.getbuffer(LBlackimage), epd.getbuffer(LRedimage))
  52. time.sleep(2)
  53. print("read bmp file")
  54. HBlackimage = Image.open('4in2b-b.bmp')
  55. HRedimage = Image.open('4in2b-r.bmp')
  56. epd.display(epd.getbuffer(HBlackimage), epd.getbuffer(HRedimage))
  57. time.sleep(2)
  58. print("read bmp file on window")
  59. blackimage1 = Image.new('1', (epd4in2b.EPD_HEIGHT, epd4in2b.EPD_WIDTH), 255) # 298*126
  60. redimage1 = Image.new('1', (epd4in2b.EPD_HEIGHT, epd4in2b.EPD_WIDTH), 255) # 298*126
  61. newimage = Image.open('100x100.bmp')
  62. blackimage1.paste(newimage, (50,10))
  63. epd.display(epd.getbuffer(blackimage1), epd.getbuffer(redimage1))
  64. epd.sleep()
  65. except:
  66. print('traceback.format_exc():\n%s',traceback.format_exc())
  67. exit()