Navigation

    • Register
    • Login
    • Search
    • Categories
    • Recent
    • Tags
    • Users
    • Groups
    • Solved
    • Unsolved
    • Search
    1. Home
    2. frederik
    • Profile
    • Following
    • Followers
    • Topics
    • Posts
    • Best
    • Groups

    Frederik Berlaen

    @frederik

    admin

    78
    Reputation
    274
    Posts
    1137
    Profile views
    6
    Followers
    1
    Following
    Joined Last Online
    Website www.typemytype.com Age 42

    frederik Follow
    drafts admin

    Best posts made by frederik

    • DrawBot 3.112 Release

      A new version is available:

      • The launch time is now at lightning speed!

      • Added a new keyword argument center for the rotate(), scale(), and skew() functions.

      The optional center argument will make the transformation be centered around the given point:

      rotate(20, center=(500, 500)) # rotate around (500, 500)
      rect(250, 250, 500, 500)
      

      Just for reference: the extra argument does the same as this example but is a lot more convenient:

      # define a center point
      centerX, centerY = 500, 500
      # translate to that center point
      translate(centerX, centerY)
      # do the transformation
      rotate(20)
      # translate back 
      translate(-centerX, -centerY)
      # draw something
      rect(250, 250, 500, 500)
      

      Download and Play!!!

      posted in Announcements
      frederik
      frederik
    • RE: Generate animated .gifs, .pdfs similar to generateMP4()?

      that is possible you can use:

      from drawBot.context.tools.gifTools import generateGif
      
      generateGif(gifPaths, destinationPath, frameRates)
      # gifPaths: a list of paths to gif files
      # destinationPath: a path where to save the animated gif
      # frameRates: a list with the same length as the gifPaths of ints in 1/100sec
      

      see https://github.com/typemytype/drawbot/blob/master/drawBot/context/tools/gifTools.py#L11

      hope this works!

      posted in General Discussion
      frederik
      frederik
    • DrawBot 3.122 is released
      • Adding bezierPath.expandStroke(width, lineCap="round", lineJoin="round", miterLimit=10) (thanks to Bahman Eslami)

      • Improved internal OpenType feature tags setting

      • Improved complex formattedString type setting

      • Improved alignment with text() and FormattedString

      • Added a DrawBot frontend for pip/PyPI to make it super easy to install third-party packages: see menu Python -> Install Python Packages...

        DrawBotPipDemo.gif

      • Fixed text stroke behavior (but is a breaking change): strokeWidth on text no longer scales with the fontSize

      • Removed support for .mov export on 10.15 and up (QTKit is no longer supported there)

      • Fixed extracting single frames from .gif files

      • Improved setup.py, so drawbot-as-a-module can be easily installed with pip using a github URL

      • All test now run on Travis CI (and soon also on GitHub Actions)

      • Removed Python 2 code

      • Many small issues were fixed

      posted in Announcements
      frederik
      frederik
    • DrawBot3.121 is released
      • Jumping to python 3.7

        If you use external packages you will need to install them for python 3.7. If you don't have python 3.7 installed you will need to do that first.

      • Improved syntax highlighting for python 3

      • Fallback fonts are also used in a svg context.

      • listNamedInstances() lists all named instances for a variable font.

      • BezierPath objects have bezierPath.line(pt1, pt2) and bezierPath.polygon(pt1, pt2, ...) methods.

      • Update internal packages!

      posted in Announcements
      frederik
      frederik
    • RE: Are there any tutorials on how to build Drawbot python files via Sublime?

      you could save the result to disk and open the result in an specified app with:

      from drawBot import *
      
      fill(random(), random(), random())
      rect(10, 10, 100, 100)
      
      path = "~/Desktop/test.pdf"
      saveImage("~/Desktop/test.pdf")
      
      import os
      os.system(f"open --background -a Preview {path}")
      
      posted in General Discussion
      frederik
      frederik
    • RE: arcTo documentation?

      I understand the confusion 🙂

      a much better explanation:

      The created arc is defined by a circle inscribed inside the angle specified by three points: the current point, the fromPoint parameter, and the toPoint parameter (in that order). The arc itself lies on the perimeter of the circle, whose radius is specified by the radius parameter. The arc is drawn between the two points of the circle that are tangent to the two legs of the angle.
      The arc usually does not contain the points in the fromPoint and toPoint parameters. If the starting point of the arc does not coincide with the current point, a line is drawn between the two points. The starting point of the arc lies on the line defined by the current point and the fromPoint parameter.

      https://developer.apple.com/documentation/appkit/nsbezierpath/1520737-appendbezierpathwitharcfrompoint

      I will adjust the drawBot documentation

      posted in General Discussion
      frederik
      frederik
    • RE: while()

      This is savedState() http://www.drawbot.com/content/canvas/state.html#drawBot.savedState

      with savedState():
          # do something
      

      This is more readable and clearer then wrapping code inside a save / restore statement.

      posted in General Discussion
      frederik
      frederik
    • RE: What's the main difference between py2 vs py3?

      For beginners there is not such a big difference:

      Strings

      All strings are unicode string, so no converting back and forth, but this is actually the best thing!!

      print

      print('hello world') requires brackets ( and )

      divisions

      Divisions are always floats so no more rounding, this is also a good thing: 1/3-> 0.333333 instead of 0

      You keep the old behaviour with 1//3

      If you dive deeper:

      dictionaries

      dict.keys(), dict.values(), dict.items() are not a lists anymore

      Looping (a for loop or a while loop) over a dictionary and changing content of that dictionary is tricky:

      for key in list(myDict.keys()):
          myDict[key] = "changed" + myDict[key]
      

      There is of course more

      • Python2 or Python3
      • What's New
      • google it 🙂
      posted in General Discussion
      frederik
      frederik
    • RE: Stephen Nixon's blogified class notes: a useful beginners' DrawBot tutorial

      @thundernixon ssssht py3.6 🙂

      posted in Tutorials
      frederik
      frederik
    • RE: Impossible typefaces?

      there are plainly of references in generative art, going from artist like Sol Lewit to graphic designers Juriaan Schrofer and many more.

      good luck!!

      posted in Code snippets
      frederik
      frederik

    Latest posts made by frederik

    • RE: Run drawbot.app as viewer only

      DrawBot has not such a feature... however you can install DrawBot as a module and use it externally building the pdf and previewing it elsewhere

      let use know if you find a solution!

      posted in General Discussion
      frederik
      frederik
    • RE: trim box in pdfs

      tried it a long time ago... didnt got it to work for some reason, so support for trim and bleed is set on hold:

      https://github.com/typemytype/drawbot/pull/304

      if you got any idea to get it to work with quartz pdf context, let me know 🙂

      posted in Feature Requests
      frederik
      frederik
    • RE: QRCodeGenerator(size, message)

      hehe, totally forgot about that one... but I prefer the solution with pyqrcode as it provides a list 0/1

      posted in General Discussion
      frederik
      frederik
    • RE: QRCodeGenerator(size, message)

      in the pip installer: pyqrcode --no-deps

      import pyqrcode
      
      blockSize = 10
      
      qr = pyqrcode.create('http://www.drawbot.com/')
      
      for x, row in enumerate(qr.code):
          for y, bit in enumerate(row):
              if bit:
                  rect(x * blockSize, y * blockSize, blockSize, blockSize)
              
      print(qr.code)
      
      posted in General Discussion
      frederik
      frederik
    • RE: QRCodeGenerator(size, message)

      no idea... but the image is indeed blurry. A quick search for CoreImage filter CIQRCodeGenerator + blurry results in lots of options but none of them apply to DrawBot.

      I would look at some python packages like https://github.com/mnooner256/pyqrcode to build the QR data and draw it with DrawBot, without round tripping to a png or image

      good luck!

      posted in General Discussion
      frederik
      frederik
    • RE: when to apply paragraphBottomSpacing

      I guess this is a coreText thing. When composing the same text with hard returns and soft returns (shift + enter) in TextEdit, there is no difference between soft and hard returns.

      97bc7514-5ad3-49a9-a954-a2362b5dd714-image.png

      I guess you'll need to script it and change the the bottom spacing for text-runs with soft returns.

      posted in Feature Requests
      frederik
      frederik
    • RE: listNamedInstances is broken ?

      thanks for the issue

      --> https://github.com/typemytype/drawbot/issues/495

      posted in General Discussion
      frederik
      frederik
    • RE: listNamedInstances is broken ?

      can you provide the not working google fonts?

      and if this is persisting, it would be handy to open an issue in the drawBot repo.

      thanks!

      posted in General Discussion
      frederik
      frederik
    • RE: Running Drawbot as a module in environments that aren't Mac OS X

      DrawBot is mac only... that will not change fast as we got now a super high level of typographic support...

      However Just started drawBotSkia which has a subset of the DrawBot api but uses skia as backend.

      see https://github.com/justvanrossum/drawbot-skia

      posted in Bugs
      frederik
      frederik
    • RE: Mute DrawBot warning ?

      you can always ignore all warnings with:

      import warnings
      warnings.simplefilter("ignore")
      

      see https://docs.python.org/3.7/library/warnings.html

      posted in General Discussion
      frederik
      frederik