epd_7in5b_V2_test.py 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. #!/usr/bin/python
  2. # -*- coding:utf-8 -*-
  3. import sys
  4. import os
  5. picdir = os.path.join(os.path.dirname(os.path.dirname(os.path.realpath(__file__))), 'pic')
  6. libdir = os.path.join(os.path.dirname(os.path.dirname(os.path.realpath(__file__))), 'lib')
  7. if os.path.exists(libdir):
  8. sys.path.append(libdir)
  9. import logging
  10. from waveshare_epd import epd7in5b_V2
  11. import time
  12. from PIL import Image,ImageDraw,ImageFont
  13. import traceback
  14. logging.basicConfig(level=logging.DEBUG)
  15. try:
  16. logging.info("epd7in5b_V2 Demo")
  17. epd = epd7in5b_V2.EPD()
  18. logging.info("init and Clear")
  19. epd.init()
  20. epd.Clear()
  21. font24 = ImageFont.truetype(os.path.join(picdir, 'Font.ttc'), 24)
  22. font18 = ImageFont.truetype(os.path.join(picdir, 'Font.ttc'), 18)
  23. # # Drawing on the Horizontal image
  24. logging.info("1.Drawing on the Horizontal image...")
  25. Himage = Image.new('1', (epd.width, epd.height), 255) # 255: clear the frame
  26. Other = Image.new('1', (epd.width, epd.height), 255) # 255: clear the frame
  27. draw_Himage = ImageDraw.Draw(Himage)
  28. draw_other = ImageDraw.Draw(Other)
  29. draw_Himage.text((10, 0), 'hello world', font = font24, fill = 0)
  30. draw_Himage.text((10, 20), '7.5inch e-Paper B', font = font24, fill = 0)
  31. draw_Himage.text((150, 0), u'微雪电子', font = font24, fill = 0)
  32. draw_other.line((20, 50, 70, 100), fill = 0)
  33. draw_other.line((70, 50, 20, 100), fill = 0)
  34. draw_other.rectangle((20, 50, 70, 100), outline = 0)
  35. draw_other.line((165, 50, 165, 100), fill = 0)
  36. draw_Himage.line((140, 75, 190, 75), fill = 0)
  37. draw_Himage.arc((140, 50, 190, 100), 0, 360, fill = 0)
  38. draw_Himage.rectangle((80, 50, 130, 100), fill = 0)
  39. draw_Himage.chord((200, 50, 250, 100), 0, 360, fill = 0)
  40. epd.display(epd.getbuffer(Himage),epd.getbuffer(Other))
  41. time.sleep(2)
  42. # Drawing on the Vertical image
  43. logging.info("2.Drawing on the Vertical image...")
  44. Limage = Image.new('1', (epd.height, epd.width), 255) # 255: clear the frame
  45. Limage_Other = Image.new('1', (epd.height, epd.width), 255) # 255: clear the frame
  46. draw_Himage = ImageDraw.Draw(Limage)
  47. draw_Himage_Other = ImageDraw.Draw(Limage_Other)
  48. draw_Himage.text((2, 0), 'hello world', font = font18, fill = 0)
  49. draw_Himage.text((2, 20), '7.5inch epd', font = font18, fill = 0)
  50. draw_Himage_Other.text((20, 50), u'微雪电子', font = font18, fill = 0)
  51. draw_Himage_Other.line((10, 90, 60, 140), fill = 0)
  52. draw_Himage_Other.line((60, 90, 10, 140), fill = 0)
  53. draw_Himage_Other.rectangle((10, 90, 60, 140), outline = 0)
  54. draw_Himage_Other.line((95, 90, 95, 140), fill = 0)
  55. draw_Himage.line((70, 115, 120, 115), fill = 0)
  56. draw_Himage.arc((70, 90, 120, 140), 0, 360, fill = 0)
  57. draw_Himage.rectangle((10, 150, 60, 200), fill = 0)
  58. draw_Himage.chord((70, 150, 120, 200), 0, 360, fill = 0)
  59. epd.display(epd.getbuffer(Limage), epd.getbuffer(Limage_Other))
  60. time.sleep(2)
  61. logging.info("3.read bmp file")
  62. epd.init_Fast()
  63. Himage = Image.open(os.path.join(picdir, '7in5_V2_b.bmp'))
  64. Himage_Other = Image.open(os.path.join(picdir, '7in5_V2_r.bmp'))
  65. epd.display(epd.getbuffer(Himage),epd.getbuffer(Himage_Other))
  66. time.sleep(2)
  67. # # partial update
  68. # logging.info("4.show time")
  69. # epd.init()
  70. # epd.display_Base_color(0xFF)
  71. # epd.init_part()
  72. # Himage = Image.new('1', (epd.width, epd.height), 0)
  73. # draw_Himage = ImageDraw.Draw(Himage)
  74. # num = 0
  75. # while (True):
  76. # draw_Himage.rectangle((10, 120, 130, 170), fill = 0)
  77. # draw_Himage.text((10, 120), time.strftime('%H:%M:%S'), font = font24, fill = 255)
  78. # epd.display_Partial(epd.getbuffer(Himage),0, 0, epd.width, epd.height)
  79. # num = num + 1
  80. # if(num == 10):
  81. # break
  82. logging.info("Clear...")
  83. epd.init()
  84. epd.Clear()
  85. logging.info("Goto Sleep...")
  86. epd.sleep()
  87. except IOError as e:
  88. logging.info(e)
  89. except KeyboardInterrupt:
  90. logging.info("ctrl + c:")
  91. epd7in5b_V2.epdconfig.module_exit(cleanup=True)
  92. exit()