I’m porting some code over from Processing to Java, and one issue I’ve come across is that processing’s precompiler turns any doubles to floats. In Eclipse however, I’ve had to explicitly cast my values as float. Still though, I get errors that I don’t understand. For instance, shouldn’t putting an f at the end of this statement fix the type mismatch (Type mismatch: cannot convert from double to
float)?
springing[n] = .05*(.17*(n+1))f;
And even on simpler statements like this I get a type mismatch. What am I doing wrong?
float theta = .01f;
Well, your second statement is correct by Java’s standards, but in your first example Java is probably trying to prevent you from converting doubles to floats due to a loss of precision that must be explicitly asked for by the programmer, as so: