aboutsummaryrefslogtreecommitdiff
path: root/msd3D
diff options
context:
space:
mode:
authorN.N. <nimon@users.sourceforge.net>2005-04-28 16:03:57 +0000
committerN.N. <nimon@users.sourceforge.net>2005-04-28 16:03:57 +0000
commit4447f41d8a048bb3a386982e7d3b9f61231b4a93 (patch)
tree3384be9d08b845f379430173fb9b831f0ca9ad83 /msd3D
parentebbeac04a2f1f57cac1bfd87b6da0f58c033e9a8 (diff)
MSD Version 0.05
svn path=/trunk/externals/nusmuk/; revision=2847
Diffstat (limited to 'msd3D')
-rwxr-xr-xmsd3D/main.cpp74
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)