PyTweening
==========
A collection of tweening (aka easing) functions implemented in Python. You can learn more about it in this blog post: https://inventwithpython.com/blog/2024/02/20/make-lively-movement-animation-with-pytweenings-tweening-functions/ and in the Nordic Game Jam talk by Martin Jonasson and Petri Purho at https://youtu.be/Fy0aCDmgnxg?si=8pgITaxjJSKFyBuB&t=159
Example Usage
=============
All tweening functions are passed an argument of a float from 0.0 (the beginning of the path) to 1.0 (the end of the path) of the tween:
>>> pytweening.linear(0.5)
0.5
>>> pytweening.linear(0.75)
0.75
>>> pytweening.linear(1.0)
1.0
>>> pytweening.easeInQuad(0.5)
0.25
>>> pytweening.easeInQuad(0.75)
0.5625
>>> pytweening.easeInQuad(1.0)
1.0
>>> pytweening.easeInOutSine(0.75)
0.8535533905932737
>>> pytweening.easeInOutSine(1.0)
1.0
The getLine() function also provides a Bresenham line algorithm implementation:
>>> pytweening.getLine(0, 0, 5, 10)
[(0, 0), (0, 1), (1, 2), (1, 3), (2, 4), (2, 5), (3, 6), (3, 7), (4, 8), (4, 9), (5, 10)]
The getLinePoint() function finds (interpolates) a point on the given line (even if it extends before or past the start or end points):
>>> getLinePoint(0, 0, 5, 10, 0.0)
(0.0, 0.0)
>>> getLinePoint(0, 0, 5, 10, 0.25)
(1.25, 2.5)
>>> getLinePoint(0, 0, 5, 10, 0.5)
(2.5, 5.0)
>>> getLinePoint(0, 0, 5, 10, 0.75)
(3.75, 7.5)
>>> getLinePoint(0, 0, 5, 10, 1.0)
(5.0, 10.0)
PyTweening also provides iterators to get the XY coordinates in a for loop between two points (though some floating-point rounding errors naturally occur):
>>> import pytweening
>>> for x, y in pytweening.iterLinear(0, 0, 100, 150, 0.1): print(x, y)
...
0.0 0.0
10.0 15.0
20.0 30.0
30.000000000000004 45.00000000000001
40.0 60.0
50.0 75.0
60.0 90.0
70.0 105.0
80.0 119.99999999999999
89.99999999999999 135.0
100.0 150.0
>>> for x, y in pytweening.iterEaseOutQuad(0, 0, 100, 150, 0.1): print(x, y)
...
0.0 0.0
19.0 28.5
36.00000000000001 54.00000000000001
51.0 76.5
64.00000000000001 96.00000000000001
75.0 112.5
84.0 126.0
90.99999999999999 136.5
96.00000000000001 144.0
99.0 148.5
100.0 150.0
Tweens
======
pytweening.linear()
data:image/s3,"s3://crabby-images/82ab1/82ab1f5b63cf36a778bf8fe355de4a7da0674430" alt="pytweening.linear()"
pytweening.easeInQuad()
data:image/s3,"s3://crabby-images/8dc75/8dc7512774a0e43098434430ce2b27104a7dac2d" alt="pytweening.easeInQuad()"
pytweening.easeOutQuad()
data:image/s3,"s3://crabby-images/c3e1e/c3e1e049679de210d6d9665bd72aa3798587830e" alt="pytweening.easeOutQuad()"
pytweening.easeInOutQuad()
data:image/s3,"s3://crabby-images/c64e4/c64e4b7b5113d0ae212ff195b0abb415e9557de6" alt="pytweening.easeInOutQuad()"
pytweening.easeInCubic()
data:image/s3,"s3://crabby-images/8d9bb/8d9bb57b1566e29390be497b6e1ec4852320a4d9" alt="pytweening.easeInCubic()"
pytweening.easeOutCubic()
data:image/s3,"s3://crabby-images/fde41/fde416de833011ce3951be4110da24456771086f" alt="pytweening.easeOutCubic()"
pytweening.easeInOutCubic()
data:image/s3,"s3://crabby-images/0e3c7/0e3c78529d2da8f0a1804eab50f075d1cba19af2" alt="pytweening.easeInOutCubic()"
pytweening.easeInQuart()
data:image/s3,"s3://crabby-images/c792e/c792e7649debcdd838554b90bd7751d028e64dd9" alt="pytweening.easeInQuart()"
pytweening.easeOutQuart()
data:image/s3,"s3://crabby-images/6b0e6/6b0e6d2e5a2a66ba3e170d608f1c8029b5416c73" alt="pytweening.easeOutQuart()"
pytweening.easeInOutQuart()
data:image/s3,"s3://crabby-images/79608/79608257f180bbbab53a89a0d8ba3ed7b2c30223" alt="pytweening.easeInOutQuart()"
pytweening.easeInQuint()
data:image/s3,"s3://crabby-images/21220/212209ed35973c4413dc9ca9621e41ec2558b338" alt="pytweening.easeInQuint()"
pytweening.easeOutQuint()
data:image/s3,"s3://crabby-images/4d34c/4d34c405cfb655bc21c975680de98a04d8d2347c" alt="pytweening.easeOutQuint()"
pytweening.easeInOutQuint()
data:image/s3,"s3://crabby-images/9f452/9f4521291f6a6801c5f87bd49219dbc9d0839c84" alt="pytweening.easeInOutQuint()"
pytweening.easeInSine()
data:image/s3,"s3://crabby-images/6b3b4/6b3b40dbb7c888f2dad59ed8bff50ea394d0bee9" alt="pytweening.easeInSine()"
pytweening.easeOutSine()
data:image/s3,"s3://crabby-images/3fc83/3fc83c3ce93a4d9b959f236b3a0a99a1a25a8110" alt="pytweening.easeOutSine()"
pytweening.easeInOutSine()
data:image/s3,"s3://crabby-images/03ccf/03ccfa2043f903aa08d66e1b737c7da1dfcc41f9" alt="pytweening.easeInOutSine()"
pytweening.easeInExpo()
data:image/s3,"s3://crabby-images/6acda/6acda92a2b303df52b1ea9a6b16b6a82fcdb26b0" alt="pytweening.easeInExpo()"
pytweening.easeOutExpo()
data:image/s3,"s3://crabby-images/5056f/5056fb1e56fee471404e15f8c94832771cbab135" alt="pytweening.easeOutExpo()"
pytweening.easeInOutExpo()
data:image/s3,"s3://crabby-images/a5f5e/a5f5eb2ecb2055ec64a3cfc15fd259a404644f09" alt="pytweening.easeInOutExpo()"
pytweening.easeInCirc()
data:image/s3,"s3://crabby-images/cf1be/cf1be2adac2aee9f30d772beb4fdd68dcfb745c5" alt="pytweening.easeInCirc()"
pytweening.easeOutCirc()
data:image/s3,"s3://crabby-images/6270e/6270e5346b45e078c1c688b35d65f1d83d7322b6" alt="pytweening.easeOutCirc()"
pytweening.easeInOutCirc()
data:image/s3,"s3://crabby-images/f5bef/f5befb978634d9dd64fce8cc4fd290fe1e0a3cb4" alt="pytweening.easeInOutCirc()"
pytweening.easeInElastic()
data:image/s3,"s3://crabby-images/c9c8c/c9c8cf1f45fdc0467e236a9bc05fabdc870e6a46" alt="pytweening.easeInElastic()"
pytweening.easeOutElastic()
data:image/s3,"s3://crabby-images/0ffbf/0ffbf1c939f7120b6f3a157393972478a4e6a21d" alt="pytweening.easeOutElastic()"
pytweening.easeInOutElastic()
data:image/s3,"s3://crabby-images/a0c49/a0c492a2d1b6a2abfa9dfa612c9f7c00801ad784" alt="pytweening.easeInOutElastic()"
pytweening.easeInBack()
data:image/s3,"s3://crabby-images/bf736/bf736ef708198b3e40da89fc5a1d7fc8e9e81fef" alt="pytweening.easeInBack()"
pytweening.easeOutBack()
data:image/s3,"s3://crabby-images/1cdcd/1cdcd9b366fc66e7ef52eb7e12cb04cfeca5facc" alt="pytweening.easeOutBack()"
pytweening.easeInOutBack()
data:image/s3,"s3://crabby-images/0c979/0c979dc8ffd42aff7253916b3304ec4ab1c58ba0" alt="pytweening.easeInOutBack()"
pytweening.easeInBounce()
data:image/s3,"s3://crabby-images/42e77/42e7743c166186dcf890c296557a93e59a23d87c" alt="pytweening.easeInBounce()"
pytweening.easeOutBounce()
data:image/s3,"s3://crabby-images/56f03/56f0329df2a9ec6a4db908d0b76155a308d2ee3b" alt="pytweening.easeOutBounce()"
pytweening.easeInOutBounce()
data:image/s3,"s3://crabby-images/d3724/d37247432aed2648f13cbaa4ea6528fb0701abfe" alt="pytweening.easeInOutBounce()"
pytweening.easeInPoly() (default degree of 2)
data:image/s3,"s3://crabby-images/2023a/2023a0177e70ff811b4a4dc91ccd28067943b54a" alt="pytweening.easeInPoly()"
pytweening.easeOutPoly() (default degree of 2)
data:image/s3,"s3://crabby-images/23894/2389477667e0ea1402624e896689ee2cdf6d84ef" alt="pytweening.easeOutPoly()"
pytweening.easeInOutPoly() (default degree of 2)
data:image/s3,"s3://crabby-images/45685/45685303f621be498b2a34de712b227e957ab873" alt="pytweening.easeInOutPoly()"
Support
-------
If you find this project helpful and would like to support its development, [consider donating to its creator on Patreon](https://www.patreon.com/AlSweigart).
Raw data
{
"_id": null,
"home_page": "https://github.com/asweigart/pytweening",
"name": "pytweening",
"maintainer": "",
"docs_url": null,
"requires_python": "",
"maintainer_email": "",
"keywords": "2D animation tween tweening easing",
"author": "Al Sweigart",
"author_email": "al@inventwithpython.com",
"download_url": "https://files.pythonhosted.org/packages/79/0c/c16bc93ac2755bac0066a8ecbd2a2931a1735a6fffd99a2b9681c7e83e90/pytweening-1.2.0.tar.gz",
"platform": null,
"description": "PyTweening\r\n==========\r\n\r\nA collection of tweening (aka easing) functions implemented in Python. You can learn more about it in this blog post: https://inventwithpython.com/blog/2024/02/20/make-lively-movement-animation-with-pytweenings-tweening-functions/ and in the Nordic Game Jam talk by Martin Jonasson and Petri Purho at https://youtu.be/Fy0aCDmgnxg?si=8pgITaxjJSKFyBuB&t=159\r\n\r\nExample Usage\r\n=============\r\n\r\nAll tweening functions are passed an argument of a float from 0.0 (the beginning of the path) to 1.0 (the end of the path) of the tween:\r\n\r\n >>> pytweening.linear(0.5)\r\n 0.5\r\n >>> pytweening.linear(0.75)\r\n 0.75\r\n >>> pytweening.linear(1.0)\r\n 1.0\r\n >>> pytweening.easeInQuad(0.5)\r\n 0.25\r\n >>> pytweening.easeInQuad(0.75)\r\n 0.5625\r\n >>> pytweening.easeInQuad(1.0)\r\n 1.0\r\n >>> pytweening.easeInOutSine(0.75)\r\n 0.8535533905932737\r\n >>> pytweening.easeInOutSine(1.0)\r\n 1.0\r\n\r\nThe getLine() function also provides a Bresenham line algorithm implementation:\r\n\r\n >>> pytweening.getLine(0, 0, 5, 10)\r\n [(0, 0), (0, 1), (1, 2), (1, 3), (2, 4), (2, 5), (3, 6), (3, 7), (4, 8), (4, 9), (5, 10)]\r\n\r\nThe getLinePoint() function finds (interpolates) a point on the given line (even if it extends before or past the start or end points):\r\n\r\n >>> getLinePoint(0, 0, 5, 10, 0.0)\r\n (0.0, 0.0)\r\n >>> getLinePoint(0, 0, 5, 10, 0.25)\r\n (1.25, 2.5)\r\n >>> getLinePoint(0, 0, 5, 10, 0.5)\r\n (2.5, 5.0)\r\n >>> getLinePoint(0, 0, 5, 10, 0.75)\r\n (3.75, 7.5)\r\n >>> getLinePoint(0, 0, 5, 10, 1.0)\r\n (5.0, 10.0)\r\n\r\nPyTweening also provides iterators to get the XY coordinates in a for loop between two points (though some floating-point rounding errors naturally occur):\r\n\r\n >>> import pytweening\r\n >>> for x, y in pytweening.iterLinear(0, 0, 100, 150, 0.1): print(x, y)\r\n ...\r\n 0.0 0.0\r\n 10.0 15.0\r\n 20.0 30.0\r\n 30.000000000000004 45.00000000000001\r\n 40.0 60.0\r\n 50.0 75.0\r\n 60.0 90.0\r\n 70.0 105.0\r\n 80.0 119.99999999999999\r\n 89.99999999999999 135.0\r\n 100.0 150.0\r\n >>> for x, y in pytweening.iterEaseOutQuad(0, 0, 100, 150, 0.1): print(x, y)\r\n ...\r\n 0.0 0.0\r\n 19.0 28.5\r\n 36.00000000000001 54.00000000000001\r\n 51.0 76.5\r\n 64.00000000000001 96.00000000000001\r\n 75.0 112.5\r\n 84.0 126.0\r\n 90.99999999999999 136.5\r\n 96.00000000000001 144.0\r\n 99.0 148.5\r\n 100.0 150.0\r\n\r\n\r\nTweens\r\n======\r\n\r\npytweening.linear()\r\n\r\ndata:image/s3,"s3://crabby-images/82ab1/82ab1f5b63cf36a778bf8fe355de4a7da0674430" alt="pytweening.linear()"\r\n\r\npytweening.easeInQuad()\r\n\r\ndata:image/s3,"s3://crabby-images/8dc75/8dc7512774a0e43098434430ce2b27104a7dac2d" alt="pytweening.easeInQuad()"\r\n\r\npytweening.easeOutQuad()\r\n\r\ndata:image/s3,"s3://crabby-images/c3e1e/c3e1e049679de210d6d9665bd72aa3798587830e" alt="pytweening.easeOutQuad()"\r\n\r\npytweening.easeInOutQuad()\r\n\r\ndata:image/s3,"s3://crabby-images/c64e4/c64e4b7b5113d0ae212ff195b0abb415e9557de6" alt="pytweening.easeInOutQuad()"\r\n\r\npytweening.easeInCubic()\r\n\r\ndata:image/s3,"s3://crabby-images/8d9bb/8d9bb57b1566e29390be497b6e1ec4852320a4d9" alt="pytweening.easeInCubic()"\r\n\r\npytweening.easeOutCubic()\r\n\r\ndata:image/s3,"s3://crabby-images/fde41/fde416de833011ce3951be4110da24456771086f" alt="pytweening.easeOutCubic()"\r\n\r\npytweening.easeInOutCubic()\r\n\r\ndata:image/s3,"s3://crabby-images/0e3c7/0e3c78529d2da8f0a1804eab50f075d1cba19af2" alt="pytweening.easeInOutCubic()"\r\n\r\npytweening.easeInQuart()\r\n\r\ndata:image/s3,"s3://crabby-images/c792e/c792e7649debcdd838554b90bd7751d028e64dd9" alt="pytweening.easeInQuart()"\r\n\r\npytweening.easeOutQuart()\r\n\r\ndata:image/s3,"s3://crabby-images/6b0e6/6b0e6d2e5a2a66ba3e170d608f1c8029b5416c73" alt="pytweening.easeOutQuart()"\r\n\r\npytweening.easeInOutQuart()\r\n\r\ndata:image/s3,"s3://crabby-images/79608/79608257f180bbbab53a89a0d8ba3ed7b2c30223" alt="pytweening.easeInOutQuart()"\r\n\r\npytweening.easeInQuint()\r\n\r\ndata:image/s3,"s3://crabby-images/21220/212209ed35973c4413dc9ca9621e41ec2558b338" alt="pytweening.easeInQuint()"\r\n\r\npytweening.easeOutQuint()\r\n\r\ndata:image/s3,"s3://crabby-images/4d34c/4d34c405cfb655bc21c975680de98a04d8d2347c" alt="pytweening.easeOutQuint()"\r\n\r\npytweening.easeInOutQuint()\r\n\r\ndata:image/s3,"s3://crabby-images/9f452/9f4521291f6a6801c5f87bd49219dbc9d0839c84" alt="pytweening.easeInOutQuint()"\r\n\r\npytweening.easeInSine()\r\n\r\ndata:image/s3,"s3://crabby-images/6b3b4/6b3b40dbb7c888f2dad59ed8bff50ea394d0bee9" alt="pytweening.easeInSine()"\r\n\r\npytweening.easeOutSine()\r\n\r\ndata:image/s3,"s3://crabby-images/3fc83/3fc83c3ce93a4d9b959f236b3a0a99a1a25a8110" alt="pytweening.easeOutSine()"\r\n\r\npytweening.easeInOutSine()\r\n\r\ndata:image/s3,"s3://crabby-images/03ccf/03ccfa2043f903aa08d66e1b737c7da1dfcc41f9" alt="pytweening.easeInOutSine()"\r\n\r\npytweening.easeInExpo()\r\n\r\ndata:image/s3,"s3://crabby-images/6acda/6acda92a2b303df52b1ea9a6b16b6a82fcdb26b0" alt="pytweening.easeInExpo()"\r\n\r\npytweening.easeOutExpo()\r\n\r\ndata:image/s3,"s3://crabby-images/5056f/5056fb1e56fee471404e15f8c94832771cbab135" alt="pytweening.easeOutExpo()"\r\n\r\npytweening.easeInOutExpo()\r\n\r\ndata:image/s3,"s3://crabby-images/a5f5e/a5f5eb2ecb2055ec64a3cfc15fd259a404644f09" alt="pytweening.easeInOutExpo()"\r\n\r\npytweening.easeInCirc()\r\n\r\ndata:image/s3,"s3://crabby-images/cf1be/cf1be2adac2aee9f30d772beb4fdd68dcfb745c5" alt="pytweening.easeInCirc()"\r\n\r\npytweening.easeOutCirc()\r\n\r\ndata:image/s3,"s3://crabby-images/6270e/6270e5346b45e078c1c688b35d65f1d83d7322b6" alt="pytweening.easeOutCirc()"\r\n\r\npytweening.easeInOutCirc()\r\n\r\ndata:image/s3,"s3://crabby-images/f5bef/f5befb978634d9dd64fce8cc4fd290fe1e0a3cb4" alt="pytweening.easeInOutCirc()"\r\n\r\npytweening.easeInElastic()\r\n\r\ndata:image/s3,"s3://crabby-images/c9c8c/c9c8cf1f45fdc0467e236a9bc05fabdc870e6a46" alt="pytweening.easeInElastic()"\r\n\r\npytweening.easeOutElastic()\r\n\r\ndata:image/s3,"s3://crabby-images/0ffbf/0ffbf1c939f7120b6f3a157393972478a4e6a21d" alt="pytweening.easeOutElastic()"\r\n\r\npytweening.easeInOutElastic()\r\n\r\ndata:image/s3,"s3://crabby-images/a0c49/a0c492a2d1b6a2abfa9dfa612c9f7c00801ad784" alt="pytweening.easeInOutElastic()"\r\n\r\npytweening.easeInBack()\r\n\r\ndata:image/s3,"s3://crabby-images/bf736/bf736ef708198b3e40da89fc5a1d7fc8e9e81fef" alt="pytweening.easeInBack()"\r\n\r\npytweening.easeOutBack()\r\n\r\ndata:image/s3,"s3://crabby-images/1cdcd/1cdcd9b366fc66e7ef52eb7e12cb04cfeca5facc" alt="pytweening.easeOutBack()"\r\n\r\npytweening.easeInOutBack()\r\n\r\ndata:image/s3,"s3://crabby-images/0c979/0c979dc8ffd42aff7253916b3304ec4ab1c58ba0" alt="pytweening.easeInOutBack()"\r\n\r\npytweening.easeInBounce()\r\n\r\ndata:image/s3,"s3://crabby-images/42e77/42e7743c166186dcf890c296557a93e59a23d87c" alt="pytweening.easeInBounce()"\r\n\r\npytweening.easeOutBounce()\r\n\r\ndata:image/s3,"s3://crabby-images/56f03/56f0329df2a9ec6a4db908d0b76155a308d2ee3b" alt="pytweening.easeOutBounce()"\r\n\r\npytweening.easeInOutBounce()\r\n\r\ndata:image/s3,"s3://crabby-images/d3724/d37247432aed2648f13cbaa4ea6528fb0701abfe" alt="pytweening.easeInOutBounce()"\r\n\r\npytweening.easeInPoly() (default degree of 2)\r\n\r\ndata:image/s3,"s3://crabby-images/2023a/2023a0177e70ff811b4a4dc91ccd28067943b54a" alt="pytweening.easeInPoly()"\r\n\r\npytweening.easeOutPoly() (default degree of 2)\r\n\r\ndata:image/s3,"s3://crabby-images/23894/2389477667e0ea1402624e896689ee2cdf6d84ef" alt="pytweening.easeOutPoly()"\r\n\r\npytweening.easeInOutPoly() (default degree of 2)\r\n\r\ndata:image/s3,"s3://crabby-images/45685/45685303f621be498b2a34de712b227e957ab873" alt="pytweening.easeInOutPoly()"\r\n\r\n\r\nSupport\r\n-------\r\n\r\nIf you find this project helpful and would like to support its development, [consider donating to its creator on Patreon](https://www.patreon.com/AlSweigart).\r\n\r\n\r\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "A collection of tweening (aka easing) functions.",
"version": "1.2.0",
"project_urls": {
"Homepage": "https://github.com/asweigart/pytweening"
},
"split_keywords": [
"2d",
"animation",
"tween",
"tweening",
"easing"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "790cc16bc93ac2755bac0066a8ecbd2a2931a1735a6fffd99a2b9681c7e83e90",
"md5": "bc7a083daeefcaaf5d2a2ed31990bb0d",
"sha256": "243318b7736698066c5f362ec5c2b6434ecf4297c3c8e7caa8abfe6af4cac71b"
},
"downloads": -1,
"filename": "pytweening-1.2.0.tar.gz",
"has_sig": false,
"md5_digest": "bc7a083daeefcaaf5d2a2ed31990bb0d",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 171241,
"upload_time": "2024-02-20T03:37:56",
"upload_time_iso_8601": "2024-02-20T03:37:56.809919Z",
"url": "https://files.pythonhosted.org/packages/79/0c/c16bc93ac2755bac0066a8ecbd2a2931a1735a6fffd99a2b9681c7e83e90/pytweening-1.2.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-02-20 03:37:56",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "asweigart",
"github_project": "pytweening",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"lcname": "pytweening"
}