當前位置: 首頁>>代碼示例>>Python>>正文


Python PIL.ImageDraw方法代碼示例

本文整理匯總了Python中PIL.ImageDraw方法的典型用法代碼示例。如果您正苦於以下問題:Python PIL.ImageDraw方法的具體用法?Python PIL.ImageDraw怎麽用?Python PIL.ImageDraw使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在PIL的用法示例。


在下文中一共展示了PIL.ImageDraw方法的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: Cutout

# 需要導入模塊: import PIL [as 別名]
# 或者: from PIL import ImageDraw [as 別名]
def Cutout(img, v):  # [0, 60] => percentage: [0, 0.2]
    assert 0.0 <= v <= 0.2
    if v <= 0.:
        return img

    v = v * img.size[0]

    return CutoutAbs(img, v)

    # x0 = np.random.uniform(w - v)
    # y0 = np.random.uniform(h - v)
    # xy = (x0, y0, x0 + v, y0 + v)
    # color = (127, 127, 127)
    # img = img.copy()
    # PIL.ImageDraw.Draw(img).rectangle(xy, color)
    # return img 
開發者ID:kakaobrain,項目名稱:autoclint,代碼行數:18,代碼來源:augmentations.py

示例2: CutoutAbs

# 需要導入模塊: import PIL [as 別名]
# 或者: from PIL import ImageDraw [as 別名]
def CutoutAbs(img, v):  # [0, 60] => percentage: [0, 0.2]
    # assert 0 <= v <= 20
    if v < 0:
        return img
    w, h = img.size
    x0 = np.random.uniform(w)
    y0 = np.random.uniform(h)

    x0 = int(max(0, x0 - v / 2.))
    y0 = int(max(0, y0 - v / 2.))
    x1 = min(w, x0 + v)
    y1 = min(h, y0 + v)

    xy = (x0, y0, x1, y1)
    color = (125, 123, 114)
    # color = (0, 0, 0)
    img = img.copy()
    PIL.ImageDraw.Draw(img).rectangle(xy, color)
    return img 
開發者ID:kakaobrain,項目名稱:autoclint,代碼行數:21,代碼來源:augmentations.py

示例3: NewImage

# 需要導入模塊: import PIL [as 別名]
# 或者: from PIL import ImageDraw [as 別名]
def NewImage(self):
        """
this must be called before doing any rendering.
Note: this replaces any previous image drawn on so be sure to
retrieve the old image before calling it again to avoid losing work
"""
        #first mode
        mode = "RGBA"
        #then other specs
        if not self.upscaled:
            global MAPWIDTH, MAPHEIGHT
            MAPWIDTH = MAPWIDTH*2
            MAPHEIGHT = MAPHEIGHT*2
            _UpdateMapDims()
            self.upscaled = True
        width = int(MAPWIDTH)
        height = int(MAPHEIGHT)
        background = MAPBACKGROUND
        dimensions = (width, height)
        self.img = PIL.Image.new(mode, dimensions, background)
        self.drawer = PIL.ImageDraw.Draw(self.img) 
開發者ID:karimbahgat,項目名稱:GeoVis,代碼行數:23,代碼來源:__init__.py

示例4: do_ascii

# 需要導入模塊: import PIL [as 別名]
# 或者: from PIL import ImageDraw [as 別名]
def do_ascii(self, text):
		try:
			i = PIL.Image.new('RGB', (2000, 1000))
			img = PIL.ImageDraw.Draw(i)
			txt = figlet_format(text, font='starwars')
			img.text((20, 20), figlet_format(text, font='starwars'), fill=(0, 255, 0))
			text_width, text_height = img.textsize(figlet_format(text, font='starwars'))
			imgs = PIL.Image.new('RGB', (text_width + 30, text_height))
			ii = PIL.ImageDraw.Draw(imgs)
			ii.text((20, 20), figlet_format(text, font='starwars'), fill=(0, 255, 0))
			text_width, text_height = ii.textsize(figlet_format(text, font='starwars'))
			final = BytesIO()
			imgs.save(final, 'png')
			final.seek(0)
			return final, txt
		except:
			return False, False 
開發者ID:NotSoSuper,項目名稱:NotSoBot,代碼行數:19,代碼來源:Fun.py

示例5: generate_ascii

# 需要導入模塊: import PIL [as 別名]
# 或者: from PIL import ImageDraw [as 別名]
def generate_ascii(self, image):
		font = PIL.ImageFont.truetype(self.files_path('FreeMonoBold.ttf'), 15, encoding="unic")
		image_width, image_height = image.size
		aalib_screen_width= int(image_width/24.9)*10
		aalib_screen_height= int(image_height/41.39)*10
		screen = aalib.AsciiScreen(width=aalib_screen_width, height=aalib_screen_height)
		im = image.convert("L").resize(screen.virtual_size)
		screen.put_image((0,0), im)
		y = 0
		how_many_rows = len(screen.render().splitlines()) 
		new_img_width, font_size = font.getsize(screen.render().splitlines()[0])
		img = PIL.Image.new("RGBA", (new_img_width, how_many_rows*15), (255,255,255))
		draw = PIL.ImageDraw.Draw(img)
		for lines in screen.render().splitlines():
			draw.text((0,y), lines, (0,0,0), font=font)
			y = y + 15
		imagefit = PIL.ImageOps.fit(img, (image_width, image_height), PIL.Image.ANTIALIAS)
		return imagefit 
開發者ID:NotSoSuper,項目名稱:NotSoBot,代碼行數:20,代碼來源:Fun.py

示例6: draw

# 需要導入模塊: import PIL [as 別名]
# 或者: from PIL import ImageDraw [as 別名]
def draw(self, draw: ImageDraw) -> None:
        super().draw(draw)
        font_w, font_h = draw.textsize(self._text, font=self._font)
        if font_h <= self.height and font_w <= self.width:
            horizontal_offset = self.abs_col
            if self._horizontal_align == Alignments.CENTER:
                horizontal_offset += (self.width - font_w) // 2
            elif self._horizontal_align == Alignments.RIGHT:
                horizontal_offset += self.width - font_w
            vertical_offset = self.abs_row
            if self._vertical_align == Alignments.CENTER:
                vertical_offset += (self.height - font_h) // 2 - 1
            elif self._vertical_align == Alignments.BOTTOM:
                vertical_offset += self.height - font_h
            draw.text((horizontal_offset, vertical_offset),
                      self.text,
                      fill=self.foreground,
                      font=self._font) 
開發者ID:zli117,項目名稱:EInk-Calendar,代碼行數:20,代碼來源:text.py

示例7: CutoutAbs

# 需要導入模塊: import PIL [as 別名]
# 或者: from PIL import ImageDraw [as 別名]
def CutoutAbs(img, v, **kwarg):
    w, h = img.size
    x0 = np.random.uniform(0, w)
    y0 = np.random.uniform(0, h)
    x0 = int(max(0, x0 - v / 2.))
    y0 = int(max(0, y0 - v / 2.))
    x1 = int(min(w, x0 + v))
    y1 = int(min(h, y0 + v))
    xy = (x0, y0, x1, y1)
    # gray
    color = (127, 127, 127)
    img = img.copy()
    PIL.ImageDraw.Draw(img).rectangle(xy, color)
    return img 
開發者ID:iBelieveCJM,項目名稱:Tricks-of-Semi-supervisedDeepLeanring-Pytorch,代碼行數:16,代碼來源:randAug.py

示例8: __init__

# 需要導入模塊: import PIL [as 別名]
# 或者: from PIL import ImageDraw [as 別名]
def __init__(self):
        global PIL
        import PIL, PIL.Image, PIL.ImageDraw, PIL.ImageTk, PIL.ImageFont
        self.upscaled = False
        self.sysfontfolders = dict([("windows","C:/Windows/Fonts/"),
                                    ("darwin", "/Library/Fonts/"),
                                    ("linux", "/usr/share/fonts/truetype/") ])
        self.fontfilenames = dict([("default", "TIMES.TTF"),
                                   ("times new roman","TIMES.TTF"),
                                   ("arial","ARIAL.TTF")]) 
開發者ID:karimbahgat,項目名稱:GeoVis,代碼行數:12,代碼來源:__init__.py

示例9: Show

# 需要導入模塊: import PIL [as 別名]
# 或者: from PIL import ImageDraw [as 別名]
def Show(self):
        import numpy, PIL, PIL.Image, PIL.ImageTk, PIL.ImageDraw
        import Tkinter as tk
        import colour
        win = tk.Tk()
        nparr = numpy.array(self.grid.lists)
        npmin = numpy.min(nparr)
        npmax = numpy.max(nparr)
        minmaxdiff = npmax-npmin
        colorstops = [colour.Color("red").rgb,colour.Color("yellow").rgb,colour.Color("green").rgb]
        colorstops = [list(each) for each in colorstops]
        colorgrad = Listy(*colorstops)
        colorgrad.Convert("250*value")
        colorgrad.Resize(int(minmaxdiff))
        valuerange = range(int(npmin),int(npmax))
        colordict = dict(zip(valuerange,colorgrad.lists))
        print len(valuerange),len(colorgrad.lists),len(colordict)
        print "minmax",npmin,npmax
        for ypos,horizline in enumerate(self.grid.lists):
            for xpos,value in enumerate(horizline):
                relval = value/float(npmax)
                self.grid.lists[ypos][xpos] = colorgrad.lists[int((len(colorgrad.lists)-1)*relval)]
        nparr = numpy.array(self.grid.lists,"uint8")
        print "np shape",nparr.shape
        img = PIL.Image.fromarray(nparr)
        drawer = PIL.ImageDraw.ImageDraw(img)
        size = 3
        for knowncell in self.knowncells:
            x,y = (knowncell.x,knowncell.y)
            drawer.ellipse((x-size,y-size,x+size,y+size),fill="black")
        img.save("C:/Users/BIGKIMO/Desktop/test.png")
        tkimg = PIL.ImageTk.PhotoImage(img)
        lbl = tk.Label(win, image=tkimg)
        lbl.pack()
        win.mainloop()
    #INTERNAL USE ONLY 
開發者ID:karimbahgat,項目名稱:GeoVis,代碼行數:38,代碼來源:listy.py

示例10: draw

# 需要導入模塊: import PIL [as 別名]
# 或者: from PIL import ImageDraw [as 別名]
def draw(self, draw: ImageDraw) -> None:
        super().draw(draw)
        for child in self._children:
            child.draw(draw) 
開發者ID:zli117,項目名稱:EInk-Calendar,代碼行數:6,代碼來源:panel.py

示例11: draw

# 需要導入模塊: import PIL [as 別名]
# 或者: from PIL import ImageDraw [as 別名]
def draw(self, draw: ImageDraw) -> None:
        if self._draw_border:
            draw.rectangle(
                (self.abs_col, self.abs_row, self.abs_col + self.width - 1,
                 self.abs_row + self.height - 1),
                outline=self.foreground,
                fill=self.background) 
開發者ID:zli117,項目名稱:EInk-Calendar,代碼行數:9,代碼來源:widget_base.py

示例12: draw

# 需要導入模塊: import PIL [as 別名]
# 或者: from PIL import ImageDraw [as 別名]
def draw(self, draw: ImageDraw) -> None:
        super().draw(draw)
        if not self.show:
            return
        horizontal_pad = self.width // 25
        bottom_pad = self.height // 4
        draw.line((self.abs_col + horizontal_pad, self.abs_row + self.height -
                   bottom_pad, self.abs_col + self.width - horizontal_pad,
                   self.abs_row + self.height - bottom_pad),
                  fill=self.foreground)
        text_w, text_h = self.font.getsize(' ')
        # How many character's size the tab will take
        tab_width_char = 14
        polygon_pts = ((self.abs_col + horizontal_pad,
                        self.abs_row + self.height - bottom_pad),
                       (self.abs_col + horizontal_pad,
                        self.abs_row + self.height - bottom_pad - text_h),
                       (self.abs_col + horizontal_pad + text_w *
                        (tab_width_char - 1),
                        self.abs_row + self.height - bottom_pad - text_h),
                       (self.abs_col + horizontal_pad +
                        text_w * tab_width_char,
                        self.abs_row + self.height - bottom_pad))
        week_day_str = WEEK_DAYS[self.date.weekday()]
        date_str = '%s, %s' % (datetime.datetime.strftime(
            self.date, ' %b %d'), week_day_str)
        draw.polygon(polygon_pts, fill=self.foreground)
        draw.text((self.abs_col + horizontal_pad,
                   self.abs_row + self.height - bottom_pad - text_h),
                  date_str,
                  fill=self.background,
                  font=self.font)
        # We save three char's space between tab and event text
        event_max_chars = ((self.width - 2 * horizontal_pad) // text_w -
                           tab_width_char - 3)
        if len(self.event) > event_max_chars:
            self.event = self.event[:event_max_chars - 3] + '...'
        draw.text(
            (self.abs_col + text_w * (tab_width_char + 3) + horizontal_pad,
             self.abs_row + self.height - bottom_pad - text_h),
            self.event,
            fill=self.foreground,
            font=self.font) 
開發者ID:zli117,項目名稱:EInk-Calendar,代碼行數:45,代碼來源:event.py

示例13: read_font

# 需要導入模塊: import PIL [as 別名]
# 或者: from PIL import ImageDraw [as 別名]
def read_font(fn):
    font = PIL.ImageFont.truetype(fn, min(w0, h0))

    # We need to make sure we scale down the fonts but preserve the vertical alignment
    min_ly = float('inf')
    max_hy = float('-inf')
    max_width = 0
    imgs = []

    for char in chars:
        print '...', char
        # Draw character
        img = PIL.Image.new("L", (w0*5, h0*3), 255)
        draw = PIL.ImageDraw.Draw(img)
        draw.text((w0, h0), char, font=font)

        # Get bounding box
        diff = PIL.ImageChops.difference(img, blank)
        lx, ly, hx, hy = diff.getbbox()
        min_ly = min(min_ly, ly)
        max_hy = max(max_hy, hy)
        max_width = max(max_width, hx - lx)
        imgs.append((lx, hx, img))

    print 'crop dims:', max_hy - min_ly, max_width
    scale_factor = min(1.0 * h / (max_hy - min_ly), 1.0 * w / max_width)
    data = []

    for lx, hx, img in imgs:
        img = img.crop((lx, min_ly, hx, max_hy))

        # Resize to smaller
        new_width = (hx-lx) * scale_factor
        new_height = (max_hy - min_ly) * scale_factor
        img = img.resize((int(new_width), int(new_height)), PIL.Image.ANTIALIAS)

        # Expand to square
        img_sq = PIL.Image.new('L', (w, h), 255)
        offset_x = (w - new_width)/2
        offset_y = (h - new_height)/2
        print offset_x, offset_y
        img_sq.paste(img, (int(offset_x), int(offset_y)))

        # Convert to numpy array
        matrix = numpy.array(img_sq.getdata()).reshape((h, w))
        matrix = 255 - matrix
        data.append(matrix)

    return numpy.array(data) 
開發者ID:erikbern,項目名稱:deep-fonts,代碼行數:51,代碼來源:create_dataset.py


注:本文中的PIL.ImageDraw方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。