79 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| [](https://gitlab.com/nicolalandro/obj2html/-/commits/main)
 | |
| [](https://gitlab.com/nicolalandro/obj2html/-/commits/main)
 | |
| 
 | |
| [](https://pypi.org/project/obj2html/)
 | |
| [](LICENSE) 
 | |
| [](https://colab.research.google.com/drive/11mWxDwAf1tR7vivAN18Vo8vLRvI9nT5T?usp=sharing)
 | |
| 
 | |
| # Obj2Html
 | |
| This lib is able to transform an .obj file to HTML that use three.js.
 | |
| In this way it is possible to have an interactive 3D view that can be used on the browser or into a jupyter notebook.
 | |
| 
 | |
| Install with `pip install obj2html` and use with `obj2html('model.obj', 'index.html')`
 | |
| 
 | |
| 
 | |
| 
 | |
| * run into jupyter notebook
 | |
| ```
 | |
| ! pip install obj2html
 | |
| ! wget https://gitlab.com/nicolalandro/obj2html/-/raw/main/test/assets/model.obj
 | |
| from obj2html import obj2html
 | |
| from IPython.display import display, HTML
 | |
| 
 | |
| obj2html('model.obj', 'index.html')
 | |
| 
 | |
| display(HTML('index.html'))
 | |
| ```
 | |
| 
 | |
| ## Features
 | |
| 
 | |
| - [x] .obj files support
 | |
| - [x] pipy delivery
 | |
| - [x] guide for notebook
 | |
| - [x] pypi doc add image
 | |
| - [x] edit html positions and other 3D params
 | |
| - [ ] dist wheel
 | |
| - [ ] load three.js as static file
 | |
| - [ ] .mat files support
 | |
| 
 | |
| # Dev
 | |
| 
 | |
| * run test
 | |
| ```
 | |
| python3.8 -m unittest discover
 | |
| ```
 | |
| * run test with coverage
 | |
| ```
 | |
| pip install coverage
 | |
| python3.8 -m coverage run --source=src -m unittest discover
 | |
| python3.8 -m coverage report -m
 | |
| ```
 | |
| * deploy pipy
 | |
| ```
 | |
| pip install twine
 | |
| 
 | |
| rm -rf dist
 | |
| 
 | |
| python setup.py sdist
 | |
| twine check dist/*
 | |
| 
 | |
| twine upload dist/*
 | |
| 
 | |
| # in one line
 | |
| ```
 | |
| 
 | |
| # References
 | |
| In this chapter I add at least a link for each of the knowledge needed for develop this project.
 | |
| * [python](https://www.python.org/): programming language for develop the tool
 | |
| * [HTML](https://www.w3schools.com/html/): markup language for the output file generated by the tool
 | |
| * [JavaScript](https://www.w3schools.com/js/): programming language used into the HTML for logic implementation 
 | |
| * [mustache](https://www.elated.com/easy-html-templates-with-mustache/): sintax for dynamic templating ( exist [pymustache](https://github.com/lotabout/pymustache) but I use a custom function with same sintax because of it does not work into js inside html)
 | |
| * [git](https://git-scm.com/doc): tool used for version control
 | |
| * [how to write a setup.py](https://medium.com/@joel.barmettler/how-to-upload-your-python-package-to-pypi-65edc5fe9c56)
 | |
| * [unittest](https://docs.python.org/3/library/unittest.html): the used python framework for test automation
 | |
| * [coverage.py](https://coverage.readthedocs.io/en/6.1.2/): lib used for code coverage computation
 | |
| * [gitlab ci/cd](https://docs.gitlab.com/ee/ci/quick_start/): for run the integration test
 | |
| * [gitlab ci/cd display coverage](https://www.activestate.com/blog/how-to-set-up-ci-cd-for-python-on-gitlab/): how to display code coverage into badge
 | |
| * [three.js](https://threejsfundamentals.org/): js lib to open and visualize 3D model
 | |
| * [Shields.io](https://shields.io/): for custom static badges like pypi
 |