101 lines
4.2 KiB
Markdown
101 lines
4.2 KiB
Markdown
[data:image/s3,"s3://crabby-images/00a10/00a1021aaaf4697ba58b37e629f6144859855580" alt="pipeline status"](https://gitlab.com/nicolalandro/obj2html/-/commits/main)
|
|
[data:image/s3,"s3://crabby-images/6209a/6209a40022733121a13201290a7e1997f5cf1195" alt="coverage report"](https://gitlab.com/nicolalandro/obj2html/-/commits/main)
|
|
|
|
[data:image/s3,"s3://crabby-images/64138/64138a7b1bf7dac18fa3b2b39ef1082d80367919" alt="License: MIT"](LICENSE)
|
|
[data:image/s3,"s3://crabby-images/a0f84/a0f8457035b4ebd5a6d5074bc1f3f8e27a4e5386" alt="pypi package"](https://pypi.org/project/obj2html/)
|
|
[data:image/s3,"s3://crabby-images/8ffba/8ffba94ba2784ef091e1cf62f2ba09474ac7a84e" alt="pypi downloads numbers"](https://pypistats.org/packages/obj2html)
|
|
|
|
[data:image/s3,"s3://crabby-images/e7985/e79852128a5f83c92496b9d734ca52d01e009a39" alt="Open In Colab"](https://colab.research.google.com/drive/11mWxDwAf1tR7vivAN18Vo8vLRvI9nT5T?usp=sharing)
|
|
[data:image/s3,"s3://crabby-images/19d33/19d33a863c74d12ab9ab758ab9e3d61d4a800567" alt="Open Streamlit in HuggingFace spaces"](https://huggingface.co/spaces/z-uo/monocular_depth_estimation)
|
|
|
|
# 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')`
|
|
|
|
data:image/s3,"s3://crabby-images/575a2/575a2a1e50867d9a1ec8ee9f18d777c7372947ba" alt=""
|
|
|
|
* run into [jupyter notebook](https://jupyter.org/) ([jupyter_example.ipynb](examples/jupyter_example.ipynb)):
|
|
```
|
|
! 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'))
|
|
```
|
|
* run into [streamlit](https://streamlit.io/) app ([streamlit_example.py](examples/streamlit_example.py)):
|
|
```
|
|
# pip install obj2html streamlit
|
|
# have a model.obj (wget https://gitlab.com/nicolalandro/obj2html/-/raw/main/test/assets/model.obj)
|
|
|
|
import streamlit as st
|
|
import streamlit.components.v1 as components
|
|
from obj2html import obj2html
|
|
|
|
html_string = obj2html("model.obj", html_elements_only=True)
|
|
components.html(html_string)
|
|
with open("model.obj") as f:
|
|
st.download_button('Download model.obj', f, file_name="download_name.obj")
|
|
```
|
|
data:image/s3,"s3://crabby-images/35fe8/35fe82f2e9328339512b7ee67c77d4bd0338b935" alt=""
|
|
|
|
|
|
## 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
|
|
- [x] add param for streamlit
|
|
- [x] document param for streamlit
|
|
- [ ] auto center and fit the 3D object on the camera view
|
|
- [ ] dist wheel for pypi
|
|
- [ ] 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
|