I'll open this up again. I've just received some JSN-SR04T V3.0 and was having similar issues to those described here. Using PlatformIO and the Arduino framework and a simple code that did the 10us pulse and measured the time of the return pulse.
data:image/s3,"s3://crabby-images/7d456/7d456abfea922251caf2439638e6268f6bbafcff" alt="10us pulseIn.JPG"
The top trace is just a line toggle as the code goes around the loop. The second trace is the echo and the bottom the trigger pulse. You can see that multiple triggers don't get a return echo. Using the function pulseIn() it times out after a second and we go around the loop again.
Using pulseInLong, that also defaults to a 1sec timeout but making the timeout 10000 ensure the code doesn’t hang for longer than necessary. but still, losses plenty of echoes.
data:image/s3,"s3://crabby-images/da06a/da06a74eb3b4dda50bc921417fb5552a22a60e3f" alt="10us trigger - pulseInLong 10000.JPG"
Next was increase the trigger to 12us It still gets the occasional lost echo
data:image/s3,"s3://crabby-images/81776/817762f4d342b910fba18e72b576873c5184c087" alt="12us = pulseInLong.JPG"
So next was 20us trigger, very few lost echoes
data:image/s3,"s3://crabby-images/259b4/259b4409a9357611a9049fc55ff2ebc717b3bf4d" alt="20us = pulseInLong.JPG"
and 30us trigger, no missing echoes
data:image/s3,"s3://crabby-images/d6a30/d6a304146476255735fd1991e26b129a571a7eb1" alt="30us = pulseInLong.JPG"
So for better reliability us a 30us trigger pulse and the pulseInLong() function with a timeout of 10000.
I concluded that the limited datasheet saying the trigger should be 10us really should say greater than 10 us.
Hope that helps somebody
Pete