2022-05-07 02:27:06 +00:00
{
"cells": [
{
"cell_type": "markdown",
"metadata": {
"id": "IK9lYTykdbtt"
},
"source": [
2022-05-08 04:10:39 +00:00
"<h1>BlendererOnline</h1>\n",
"<small><i>Uses some codes of <a href='https://urlzs.com/4hkfp' target='_blank' rel='noopener'>BlenderRender</a> by <a href='https://urlzs.com/ToHpE' target='_blank' rel='noopener'>aniquetahir</a>.</i></small>\n",
2022-05-07 03:03:51 +00:00
"\n",
2022-05-08 04:10:39 +00:00
"<p>Render Blender files online, for free. </p>"
2022-05-07 02:27:06 +00:00
]
},
{
"cell_type": "code",
2022-05-08 04:10:39 +00:00
"execution_count": 3,
2022-05-07 02:27:06 +00:00
"metadata": {
"id": "F5vZwPfYenN8"
},
"outputs": [],
"source": [
"#@title Configuration\n",
"class formatting:\n",
" clear = '\\033[0m'\n",
" class color: \n",
" purple = '\\033[95m'\n",
" cyan = '\\033[96m'\n",
" cyan_dark = '\\033[36m'\n",
" blue = '\\033[94m'\n",
" green = '\\033[92m'\n",
" yellow = '\\033[93m'\n",
" red = '\\033[91m'\n",
" class font:\n",
" bold = '\\033[1m'\n",
" underline = '\\033[4m'\n",
"\n",
"## Define screen functions. \n",
"def clear(): from IPython.display import clear_output; return clear_output()\n",
"\n",
"class info: # screen messages\n",
" def status(message): print(formatting.font.bold + 'Status: \\t' + formatting.clear + message)\n",
" def err(message): print(formatting.font.bold + formatting.color.red + 'Error: \\t' + formatting.clear + formatting.clear + message)\n",
" def warning(message): print(formatting.font.bold + formatting.color.yellow + 'Warning: \\t' + formatting.clear + formatting.clear + message)\n",
" def success(message): print(formatting.font.bold + formatting.color.green + 'Success: \\t' + formatting.clear + formatting.clear + message)\n",
"\n",
"def check_compatibility(): \n",
" try: from google.colab import files\n",
" except: raise TypeError(\"No! Please run this in \" + formatting.font.bold + 'Google CoLab' + formatting.clear + '. ')\n",
"\n",
2022-05-07 04:58:09 +00:00
"def getExtension(fileName): \n",
" import os\n",
" fileName_split = os.path.splitext(fileName)\n",
"\n",
" return fileName_split[1].lower()\n",
"\n",
2022-05-07 02:27:06 +00:00
"def UploadBlendFile(): # Make sure that the file is actually a Blender file. \n",
" check_compatibility()\n",
2022-05-07 04:58:09 +00:00
"\n",
" import pathlib; from google.colab import files\n",
2022-05-07 02:27:06 +00:00
" uploaded_file = files.upload()\n",
" \n",
" return uploaded_file\n",
"\n",
2022-05-08 03:50:53 +00:00
"def checkValidUpload(what): # Make sure that the user has that file uploaded when specifying the name. \n",
2022-05-08 04:10:39 +00:00
" import os\n",
" if not(os.system('cat ' + str(what))):\n",
" info.warning('File does not exist.')\n",
" return (not(os.system('cat ' + str(what))))\n",
2022-05-08 03:50:53 +00:00
"\n",
"def properlySetFrames(frame_start, frame_end): \n",
" if frame_start == frame_end: return frame_end\n",
" else: return False\n",
2022-05-07 04:58:09 +00:00
"\n",
2022-05-07 02:27:06 +00:00
"class configuration: \n",
" #@markdown ### Input\n",
2022-05-07 04:58:09 +00:00
" \n",
2022-05-08 03:50:53 +00:00
" upload_new = 0 #@param {type:\"slider\", min:0, max:1, step:1}\n",
" if upload_new == True: UploadBlendFile()\n",
2022-05-07 04:58:09 +00:00
"\n",
2022-05-08 03:50:53 +00:00
" # user preferred file name\n",
2022-05-08 04:10:39 +00:00
" blend_fileName = 'test.blend' #@param {type: \"string\"}\n",
" blend_fileName = blend_fileName.strip()\n",
" if blend_fileName != None: \n",
" if getExtension(blend_fileName) != '.blend' : blend_fileName = (str(blend_fileName) + '.blend'); checkValidUpload(blend_fileName)\n",
2022-05-07 02:27:06 +00:00
"\n",
2022-05-07 04:58:09 +00:00
" #@markdown ### Processing\n",
2022-05-07 02:27:06 +00:00
" renderer = \"CYCLES\" #@param [\"CYCLES\", \"BLENDER_EEVEE\", \"BLENDER_WORKBENCH\"]\n",
2022-05-08 03:50:53 +00:00
" device = \"CPU\" #@param [\"CPU\", 'CUDA', 'OPTIX', 'HIP', 'METAL']\n",
"\n",
" #@markdown ### Animation\n",
2022-05-07 04:58:09 +00:00
" frame_start = 1 #@param {type: \"number\"}\n",
2022-05-08 03:50:53 +00:00
" frame_end = 1 #@param {type: \"number\"}\n",
"\n",
" frame = properlySetFrames(frame_start, frame_end)\n",
"\n",
" #@markdown ### Output\n",
" output_fileFormat = 'JPEG' #@param ['TGA', 'RAWTGA', 'JPEG', 'IRIS', 'IRIZ', 'AVIRAW', 'AVIJPEG', 'PNG', 'BMP']\n"
2022-05-07 02:27:06 +00:00
]
},
{
"cell_type": "code",
2022-05-08 04:10:39 +00:00
"execution_count": 5,
2022-05-07 02:27:06 +00:00
"metadata": {
"colab": {
2022-05-08 04:10:39 +00:00
"base_uri": "https://localhost:8080/"
2022-05-07 02:27:06 +00:00
},
"id": "8szOTQ7TTgNm",
2022-05-08 04:10:39 +00:00
"outputId": "f4464c1a-6a83-44fd-edcc-212eb4bfc9ea"
2022-05-07 02:27:06 +00:00
},
"outputs": [
{
2022-05-08 04:10:39 +00:00
"name": "stdout",
2022-05-08 12:55:48 +00:00
"output_type": "stream",
2022-05-07 02:27:06 +00:00
"text": [
2022-05-08 04:10:39 +00:00
"\u001b[1mStatus: \t\u001b[0mStarting render of file test.blend…\n",
"src/tcmalloc.cc:283] Attempt to free invalid pointer 0x7fc749c1e040 \n"
2022-05-07 02:27:06 +00:00
]
}
],
"source": [
"import os\n",
"\n",
"class formatting:\n",
" clear = '\\033[0m'\n",
" class color: \n",
" purple = '\\033[95m'\n",
" cyan = '\\033[96m'\n",
" cyan_dark = '\\033[36m'\n",
" blue = '\\033[94m'\n",
" green = '\\033[92m'\n",
" yellow = '\\033[93m'\n",
" red = '\\033[91m'\n",
" class font:\n",
" bold = '\\033[1m'\n",
" underline = '\\033[4m'\n",
"\n",
"class info: # screen messages\n",
2022-05-08 03:50:53 +00:00
" def status(message): print(formatting.font.bold + 'Status: \\t' + formatting.clear + message)\n",
" def err(message): print(formatting.font.bold + formatting.color.red + 'Error: \\t' + formatting.clear + formatting.clear + message)\n",
" def warning(message): print(formatting.font.bold + formatting.color.yellow + 'Warning: \\t' + formatting.clear + formatting.clear + message)\n",
" def success(message): print(formatting.font.bold + formatting.color.green + 'Success: \\t' + formatting.clear + formatting.clear + message)\n",
2022-05-07 02:27:06 +00:00
"\n",
2022-05-08 04:10:39 +00:00
"def check_fieldsFilled(): # Make sure that the user has run the previous cell. \n",
2022-05-08 03:50:53 +00:00
" try: \n",
" clear()\n",
" except: \n",
" raise ImportError(formatting.font.bold + 'Please run the configurations cell before rendering. ' + formatting.clear + 'No default values are to be passed by this cell. ')\n",
" return False\n",
" else: \n",
2022-05-08 04:10:39 +00:00
" if configuration.blend_fileName == None: \n",
2022-05-08 12:55:48 +00:00
" raise ImportError(formatting.font.bold + 'The file name for the Blender file is missing. ' + formatting.clear + 'It is a required field. ')\n",
2022-05-08 04:10:39 +00:00
" else: \n",
" return True\n",
2022-05-07 02:27:06 +00:00
"\n",
"def install(what, isCritical = False):\n",
2022-05-07 03:03:51 +00:00
" if what == \"required\":\n",
" install(\"blender\", True)\n",
" install(\"libboost-all-dev\")\n",
" install(\"libgl1-mesa-dev\")\n",
2022-05-08 04:10:39 +00:00
" clear()\n",
2022-05-07 03:03:51 +00:00
" else:\n",
" info.status('Installing ' + what + '…')\n",
" try:\n",
" if os.system('apt install ' + what + ' -y') > 0: \n",
" if os.system('apt-get install ' + what + ' -y') > 0: \n",
" if os.system('apt install --fix-broken ' + what + ' -y'): raise\n",
" except:\n",
" errorMsg = (what + ' could not get installed. ')\n",
" if isCritical: raise SystemError(errorMsg + 'Unfortunately, this module is required. ')\n",
" else: info.err(errorMsg)\n",
" else: \n",
" os.system('apt clean && apt autoremove -y')\n",
" info.success('Installed '+ what + '.')\n",
2022-05-08 03:50:53 +00:00
"\n",
"def render(): \n",
2022-05-08 04:10:39 +00:00
" def checkInvalidUploadProceed(): # Make sure user is sure that the file does exist. \n",
2022-05-08 03:50:53 +00:00
" clear()\n",
2022-05-08 04:10:39 +00:00
" if not(checkValidUpload(configuration.blend_fileName)): \n",
2022-05-08 03:50:53 +00:00
" confirm_tries = 2; confirm_count = 0; \n",
" while confirm_count < confirm_tries: \n",
" try:\n",
" input('This will cause errors. Do you want to continue? \\n[\\tYes (⏎)\\t]')\n",
" except KeyboardInterrupt: \n",
" return False\n",
" else: \n",
" confirm_count = confirm_count + 1\n",
" if confirm_count == 2: return True\n",
2022-05-08 04:10:39 +00:00
" else: return True\n",
2022-05-08 03:50:53 +00:00
"\n",
"\n",
" def start_render(): \n",
" # Command line arguments from here: https://urlzs.com/MiUkt\n",
" # Simplified here: https://urlzs.com/au5z7\n",
"\n",
" info.status('Starting render of file ' + configuration.blend_fileName + '…')\n",
"\n",
2022-05-08 04:10:39 +00:00
" if not(configuration.frame): \n",
2022-05-08 03:50:53 +00:00
" !blender -b {configuration.blend_fileName} -o ./output_ -E {configuration.renderer} -F {configuration.output_fileFormat} -x 1 -s {configuration.frame_start} -e {configuration.frame_end} --cycles-device {configuration.device}\n",
" else: \n",
" !blender -b {configuration.blend_fileName} -o ./output_ -E {configuration.renderer} -F {configuration.output_fileFormat} -x 1 -f {configuration.frame} --cycles-device {configuration.device}\n",
2022-05-07 02:27:06 +00:00
"\n",
2022-05-08 12:55:48 +00:00
" info.status('Render of file ' + configuration.blend_fileName + ' has completed.')\n",
"\n",
2022-05-08 04:10:39 +00:00
" if checkInvalidUploadProceed(): \n",
" start_render()\n",
"\n",
2022-05-07 02:27:06 +00:00
"def main():\n",
2022-05-08 04:10:39 +00:00
" check_fieldsFilled();\n",
2022-05-08 03:50:53 +00:00
" install(\"required\");\n",
2022-05-08 04:10:39 +00:00
" render();\n",
2022-05-07 02:27:06 +00:00
"\n",
"main()"
]
},
{
2022-05-08 12:55:48 +00:00
"cell_type": "markdown",
"metadata": {},
2022-05-07 02:27:06 +00:00
"source": [
2022-05-08 12:55:48 +00:00
"<h2>Utilities</h2>"
2022-05-07 02:27:06 +00:00
]
},
{
"cell_type": "code",
2022-05-08 03:50:53 +00:00
"execution_count": null,
2022-05-07 02:27:06 +00:00
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/",
"height": 557
},
"id": "ilwDQe4gb3O5",
"outputId": "8d38304b-87c8-4887-94ae-8104865d8148"
},
"outputs": [
{
"data": {
"image/png": "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
"text/plain": [
"<IPython.core.display.Image object>"
]
},
"execution_count": 8,
"metadata": {
"tags": []
},
"output_type": "execute_result"
}
],
"source": [
2022-05-08 12:55:48 +00:00
"#@title Picture Viewer\n",
"#@title Configuration\n",
"class formatting:\n",
" clear = '\\033[0m'\n",
" class color: \n",
" purple = '\\033[95m'\n",
" cyan = '\\033[96m'\n",
" cyan_dark = '\\033[36m'\n",
" blue = '\\033[94m'\n",
" green = '\\033[92m'\n",
" yellow = '\\033[93m'\n",
" red = '\\033[91m'\n",
" class font:\n",
" bold = '\\033[1m'\n",
" underline = '\\033[4m'\n",
"\n",
"## Define screen functions. \n",
"def clear(): from IPython.display import clear_output; return clear_output()\n",
"\n",
"class fileViewer: \n",
" image_fileName = '' #@param {type: \"string\"}\n",
"\n",
"def fixFormatImage(): \n",
" ## Give file format of png if the user didn't give any. Of course they should put it. \n",
2022-05-08 13:08:26 +00:00
" if getExtension(fileViewer.image_fileName) == None: fileViewer.image_fileName = (str(fileViewer.image_fileName) + '.png')\n",
2022-05-08 12:55:48 +00:00
"\n",
"def preview(): \n",
" clear()\n",
" try: \n",
" from IPython.display import Image\n",
" Image(filename=fileViewer.image_fileName)\n",
" except:\n",
" info.err(formatting.font.bold + 'Could not preview the image. ' + formatting.clear + 'Make sure that the file is present and that the file format is correct.')\n",
"\n",
"def main(): \n",
" fixFormatImage(); preview()\n",
"\n",
"main()"
2022-05-07 02:27:06 +00:00
]
},
2022-05-08 13:08:26 +00:00
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"#@title Video Viewer\n",
"#@title Configuration\n",
"class formatting:\n",
" clear = '\\033[0m'\n",
" class color: \n",
" purple = '\\033[95m'\n",
" cyan = '\\033[96m'\n",
" cyan_dark = '\\033[36m'\n",
" blue = '\\033[94m'\n",
" green = '\\033[92m'\n",
" yellow = '\\033[93m'\n",
" red = '\\033[91m'\n",
" class font:\n",
" bold = '\\033[1m'\n",
" underline = '\\033[4m'\n",
"\n",
"## Define screen functions. \n",
"def clear(): from IPython.display import clear_output; return clear_output()\n",
"\n",
"class fileViewer: \n",
" video_fileName = '' #@param {type: \"string\"}\n",
"\n",
"def fixFormatVideo(): \n",
" ## Give file format of png if the user didn't give any. Of course they should put it. \n",
" if (getExtension(fileViewer.video_fileName) == None or getExtension(fileViewer.video_fileName) == ''): fileViewer.video_fileName = (str(fileViewer.video_fileName) + '.avi')\n",
"\n",
"def preview(): \n",
" clear()\n",
" try: \n",
" from IPython.display import Video\n",
" Video(fileViewer.video_fileName, embed=True)\n",
" except:\n",
" info.err(formatting.font.bold + 'Could not preview the video. ' + formatting.clear + 'Make sure that the file is present and that the file format is correct.')\n",
"\n",
"def main(): \n",
" fixFormatVideo(); preview()\n",
"\n",
"main()"
]
},
2022-05-07 02:27:06 +00:00
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"id": "Kvv_WzdIf1CA"
},
"outputs": [],
2022-05-08 12:55:48 +00:00
"source": []
2022-05-07 02:27:06 +00:00
}
],
"metadata": {
"accelerator": "GPU",
"colab": {
"name": "BlenderRender.ipynb",
2022-05-08 03:50:53 +00:00
"provenance": []
2022-05-07 02:27:06 +00:00
},
"kernelspec": {
"display_name": "Python 3 (ipykernel)",
"language": "python",
"name": "python3"
},
"language_info": {
"name": "python",
"version": "3.10.4"
}
},
"nbformat": 4,
"nbformat_minor": 0
2022-05-08 12:55:48 +00:00
}