Comments (10)
Hi @vianamp
thanks for your interest!
Actually the show()
command should be inside the loop. Check out for example this:
from vtkplotter import *
import numpy as np
vp = Plotter(interactive=False)
coo = np.random.rand(32*12).reshape(32,12)
for i in range(len(coo)):
u = coo[i,3:6]
v = coo[i,6:9]
q = coo[i,9:12]
ell = Ellipsoid(pos=(2.5*coo[i,0], 2.5*coo[i,1], 2.5*coo[i,2]),
axis1=u, axis2=v, axis3=q)
scals = [i] * ell.N()
ell.pointColors(scals, vmin=0, vmax=31)
vp += ell
vp.show()
interactive()
Let me know if you need more help. Also, you can find more examples of animations in example/simulations directory which may fit your need.
from vedo.
Yes.. the jupyter functionality is still experimental and at the moment is not working well with loops.
It' s on my to-do list..
If you need to work in notebooks you still have the option of setting:
from vtkplotter import *
embedWindow(False)
then the normal vtk rendering window will pop up.
from vedo.
Thanks for quick reply. What if I need only one timepoint to be shown at the time? And also to keep the bounding box fixed at the largest size that fits all the objects?
from vedo.
Also, I got this error when I tried to run your code on a jupyter notebook:
AttributeError Traceback (most recent call last)
<ipython-input-12-4b069e1c07cd> in <module>()
13 vp.show()
14
---> 15 interactive()
~/anaconda3/envs/qcb/lib/python3.6/site-packages/vtkplotter/plotter.py in interactive()
259 if settings.plotter_instance:
260 if hasattr(settings.plotter_instance, 'interactor'):
--> 261 settings.plotter_instance.interactor.Start()
262 return settings.plotter_instance
263
AttributeError: 'NoneType' object has no attribute 'Start'
from vedo.
There are 2 ways of doing it:
- either you create an invisible box that contains the object that you want to create afterwards or
- render the scene once outside the loop with e.g.
vp.show(world, ell, resetcam=False)
from vtkplotter import *
import numpy as np
vp = Plotter(interactive=False)
coo = np.random.rand(32*12).reshape(32,12)
world = Box([1,1,1], 5,5,5).wireframe().alpha(0) ##########
for i in range(len(coo)):
u = coo[i,3:6]
v = coo[i,6:9]
q = coo[i,9:12]
ell = Ellipsoid(pos=(2.5*coo[i,0], 2.5*coo[i,1], 2.5*coo[i,2]),
axis1=u, axis2=v, axis3=q)
scals = [i] * ell.N()
ell.pointColors(scals, vmin=0, vmax=31)
vp.show(world, ell)
interactive()
About the jupyter thing indeed this a current limitation (or ... bug) due to how the K3D backend works...
One needs to collect the object returned by show()
and then just expose it outside the loop...
from vedo.
I see what you mean. My final code looks like this:
np.random.seed(1234)
n = 8
vp = Plotter(interactive=False)
coo = np.random.rand(n*12).reshape(n,12)
world = Box([1,1,1], 5,5,5).wireframe().alpha(0)
for i in range(n):
u = coo[i,3:6]
v = coo[i,6:9]
q = coo[i,9:12]
ell = Ellipsoid(pos=(2.5*coo[i,0], 2.5*coo[i,1], 2.5*coo[i,2]), axis1=u, axis2=v, axis3=q)
scals = [i] * ell.N()
ell.pointColors(scals, vmin=0, vmax=n)
vp += ell
plt = vp.show(world, ell, resetcam=False)
plt
However, I don't actually see the animation. Only the last timepoint is shown.
from vedo.
How to fix the viewing angle to the first frame. The object moves a little bit in the following gif.
Thanks~
@marcomusy
from vedo.
you can either add an invisible box:
vp += Box((1,1,1), length=5, width=5, height=5).wireframe().alpha(0)
or avoid resetting the camera later with
vp.show(resetcam=False)
in the ex. above, as the the object are added randomly, the first solution is probably the best.
from vedo.
Hi, marcomusy~
How to add a description for each frame like: "frame: {}/{}.format(current, all)"
?
If I set by txt = Text(...)
with background, it seems to get slower and slower, if I use vp.clear(txt)
, there will be flashes.
from vedo.
@LogWell
thanks for spotting the problem, I'll investigate that.
from vedo.
Related Issues (20)
- Adding item to Group HOT 2
- Arrow object's top point HOT 2
- Group objects HOT 1
- Help ! Legosurface Error HOT 2
- version 2024.5.2 `show()` function returns error HOT 4
- quality and resolution of the video HOT 3
- Make load functions compatible with pathlib.Path HOT 1
- Creating a plot with objects out of scene, seems to break calls to render HOT 1
- Mesh.volume() and Mesh.is_closed() don't work with Boxes and Cylinders HOT 1
- compute_normals() unexpectedly changes the appearance of a Mesh HOT 2
- Cut volume with volume HOT 1
- seg fault on vertex normal and texture indices in obj format to off conversion HOT 2
- Issues with boolean operation HOT 4
- Touching objects handling in isosurface_discrete HOT 10
- Problems with boolean operations on concave polyhedrons HOT 4
- Problem with mesh formation
- mesh.cells datatype HOT 2
- Axes order of numpy array HOT 2
- computing volume of intersecting concave polyhedra HOT 1
- 2D images become non-pickable after changing cmap
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from vedo.