I was able to take some time over the last few weeks to investigate the new 4.0 beta. While I realize that 4.0 is in the initial beta phase and has limited functionality, it is pretty obvious that the API has been substantially overhauled between 3.x and 4.0. Some changes are largely syntactical, but others - especially those changes relating to Map and Layers - require a rethinking of how a mapping application is constructed. Before my project starts to consider how to rearchitect its current application, I was hoping to get a good read on what constructs may be supported in future betas and the final release of 4.0. What follows are several "groupings" of API functionality that I have heavily leveraged in the 3.x versions of the API, but do not appear to be supported in 4.0 Beta 1.
Any insignt from the Esri developers out there would be greatly appreciated 
Solved! Go to Solution.
Hi Mike,
These are some great questions. You are right, 4.0beta1 is very limited in functionality compared to 3.x versions of the API. 4.0 beta1 is primarily a developer preview to showcase the direction we're going in re-designing the API, which clearly affects the way it is consumed by developers and users. While these are substantial differences in many cases, the hope is that the code structure will be easier to work with and more developer friendly by the time of our final release. Now about your questions:
1. Many of the same map navigation properties exist in 4.0, but on the MapView or SceneView as you have noted. You can use MapView.zoom, .center, .scale, .extent to set the extent. As far as actual navigation methods go, you can use MapView.animateTo() to accomplish this. This sample shows an example of how animateTo() may be used to zoom to graphics, geometries, or a simple object with center and zoom properties.
2. This will be another major difference in the 4.0 API. Many of these navigation methods such as enabling/disabling map navigation will be handled with the GestureManager class. Keep in mind that this class is not complete and not yet fully functional. So keep an eye out for changes coming here that will communicate how to use GestureManager for these purposes.
3. This would also be handled in GestureManager.
Hopefully, this information is helpful. Again, each of the betas will feel limited compared to the 3.x versions, but by the time we release 4.0 final next year, solutions to these questions will all be answered. Thanks for your feedback and input.
Hi Mike,
These are some great questions. You are right, 4.0beta1 is very limited in functionality compared to 3.x versions of the API. 4.0 beta1 is primarily a developer preview to showcase the direction we're going in re-designing the API, which clearly affects the way it is consumed by developers and users. While these are substantial differences in many cases, the hope is that the code structure will be easier to work with and more developer friendly by the time of our final release. Now about your questions:
1. Many of the same map navigation properties exist in 4.0, but on the MapView or SceneView as you have noted. You can use MapView.zoom, .center, .scale, .extent to set the extent. As far as actual navigation methods go, you can use MapView.animateTo() to accomplish this. This sample shows an example of how animateTo() may be used to zoom to graphics, geometries, or a simple object with center and zoom properties.
2. This will be another major difference in the 4.0 API. Many of these navigation methods such as enabling/disabling map navigation will be handled with the GestureManager class. Keep in mind that this class is not complete and not yet fully functional. So keep an eye out for changes coming here that will communicate how to use GestureManager for these purposes.
3. This would also be handled in GestureManager.
Hopefully, this information is helpful. Again, each of the betas will feel limited compared to the 3.x versions, but by the time we release 4.0 final next year, solutions to these questions will all be answered. Thanks for your feedback and input.
So navigation methods such as enabling/disabling map navigation will be handled with the GestureManager class. Does this mean that applications that use the current non-GestureManager class in 3.x API will need to be recoded in these areas?
Thanks, Kristian.  This is definitely helpful.
I thought the GestureManager might be the object to "replace" eventing. I even tried to implement GestureManager, but without examples or additional documentation to help me, I didn't have any success. It sounds like it is a work in progress anyway, so I will probably wait until a future beta to test its implementation.
You're right. It is still a work in progress. GestureManager was not ready in beta1, but it will be ready in a future release.
