diff options
author | N.N. <nimon@users.sourceforge.net> | 2005-04-28 16:03:57 +0000 |
---|---|---|
committer | N.N. <nimon@users.sourceforge.net> | 2005-04-28 16:03:57 +0000 |
commit | 4447f41d8a048bb3a386982e7d3b9f61231b4a93 (patch) | |
tree | 3384be9d08b845f379430173fb9b831f0ca9ad83 /msd3D | |
parent | ebbeac04a2f1f57cac1bfd87b6da0f58c033e9a8 (diff) |
MSD Version 0.05
svn path=/trunk/externals/nusmuk/; revision=2847
Diffstat (limited to 'msd3D')
-rwxr-xr-x | msd3D/main.cpp | 74 |
1 files changed, 51 insertions, 23 deletions
diff --git a/msd3D/main.cpp b/msd3D/main.cpp index fff45bc..6808f08 100755 --- a/msd3D/main.cpp +++ b/msd3D/main.cpp @@ -333,56 +333,84 @@ protected: { // displace mass(es) named Id to a certain position t_int i; - const t_symbol *sym = GetSymbol(argv[0]); + const t_symbol *sym = GetASymbol(argv[0]); t_mass **mi; if (argc != 2) - error("posX : Idmass value"); + error("posX : Id/Nomass value"); if (GetFloat(argv[1]) < Xmax && GetFloat(argv[1]) > Xmin) - for (i=0, mi=mass; i<nb_mass;mi++, i++) - { - if (sym == (*mi)->Id) - (*mi)->posX = GetAFloat(argv[1]); - } + if (sym ==0) + for (i=0, mi=mass; i<nb_mass; mi++, i++) + { + if (GetInt(argv[0]) == (*mi)->nbr) { + (*mi)->posX = GetFloat(argv[1]); + (*mi)->posX2 = GetFloat(argv[1]); + break; + } + } + else + for (i=0, mi=mass; i<nb_mass; mi++, i++) + if (sym == (*mi)->Id) { + (*mi)->posX = GetFloat(argv[1]); + (*mi)->posX2 = GetFloat(argv[1]); + } } void m_posY(int argc,t_atom *argv) { // displace mass(es) named Id to a certain position t_int i; - const t_symbol *sym = GetSymbol(argv[0]); + const t_symbol *sym = GetASymbol(argv[0]); t_mass **mi; if (argc != 2) - error("posY : Idmass value"); + error("posY : Id/Nomass value"); if (GetFloat(argv[1]) < Ymax && GetFloat(argv[1]) > Ymin) - for (i=0, mi=mass; i<nb_mass;mi++, i++) - { - if (sym == (*mi)->Id) - (*mi)->posY = GetFloat(argv[1]); - } - + if (sym ==0) + for (i=0, mi=mass; i<nb_mass; mi++, i++) + { + if (GetInt(argv[0]) == (*mi)->nbr) { + (*mi)->posY = GetFloat(argv[1]); + (*mi)->posY2 = GetFloat(argv[1]); + break; + } + } + else + for (i=0, mi=mass; i<nb_mass; mi++, i++) + if (sym == (*mi)->Id) { + (*mi)->posY = GetFloat(argv[1]); + (*mi)->posY2 = GetFloat(argv[1]); + } } void m_posZ(int argc,t_atom *argv) { // displace mass(es) named Id to a certain position t_int i; - const t_symbol *sym = GetSymbol(argv[0]); + const t_symbol *sym = GetASymbol(argv[0]); t_mass **mi; if (argc != 2) - error("posZ : Idmass value"); + error("posY : Id/Nomass value"); if (GetFloat(argv[1]) < Zmax && GetFloat(argv[1]) > Zmin) - for (i=0, mi=mass; i<nb_mass;mi++, i++) - { - if (sym == (*mi)->Id) - (*mi)->posZ = GetFloat(argv[1]); - } - + if (sym ==0) + for (i=0, mi=mass; i<nb_mass; mi++, i++) + { + if (GetInt(argv[0]) == (*mi)->nbr) { + (*mi)->posZ = GetFloat(argv[1]); + (*mi)->posZ2 = GetFloat(argv[1]); + break; + } + } + else + for (i=0, mi=mass; i<nb_mass; mi++, i++) + if (sym == (*mi)->Id) { + (*mi)->posZ = GetFloat(argv[1]); + (*mi)->posZ2 = GetFloat(argv[1]); + } } void m_set_mobile(int argc,t_atom *argv) |