Xj3D Evolution
Xj3D is an open-source Java implementation for X3D graphics. Xj3D is used to demonstrate many capabilities for specification development and supports a variety of valuable projects.
Contents
Goals and Timeline
We are considering how to further stabilize, improve and accelerate development of the Xj3D code base. This page is collecting ideas for potential improvement.
These are familiar topics and lots of great work continues. It should be straightforward for interested stakeholders to discuss and agree on next steps.
- Now ready for Xj3D source community and X3D working group teleconference, Monday 30 June 2014, 10-11am pacific
- Our goal is to have everything transitioned, stabilized, announced and ready for new contributions at the Web3D 2014 Conference and SIGGRAPH 2014 Conference in Vancouver Canada, 8-10 and 11-14 August.
Source Code Hosting
In order to achieve greater participation and development, the code needs to move to a stable public open-source repository. This will gain a lot more visibility among programmers who might want to contribute.
- xj3d.org has hosted the source for many years but development has been intermittent and somewhat less than fully open.
- The NPS branch of Xj3D is used for experimental development. Proven changes and unit tests are integrated back into the Xj3D trunk when stable.
Conclusion: moving to SourceForge is our planned approach to meet group goals for unveiling and evangelizing at Web3D Conference and SIGGRAPH 2014.
SourceForge
- The current xj3d.org code is in subversion, this can be migrated completely
- Web3D already has numerous assets checked into the Sourceforge X3D project, it is available
- Sourceforge also has related projects for jgeom and open-dis
- Multiple participants have experience with using and administering the Sourceforge site
- Instead of using the Web3D X3D project, can Web3D instead create a new and separate Sourceforge project for Xj3D to keep things a bit simpler?
- Can the new site maintain a side-by-side mirror of Xj3D.org and an refactored trunk, so that all updates are reliably accessible?
- Can the new site keep a new trunk adjacent but separate so that new developers can get started quickly?
- There is a lot of merit to using a version-control system that is familiar, especially as we try to integrate other Xj3D variants and prepare for SIGGRAPH milestones.
GitHub
- GitHub includes the X3DOM project and a few other X3D-related projects.
- We have reserved an X3D Xj3D project site on GitHub as a placeholder. This might be useful for cross-links and future evolution.
- The github pricing policy does not cost money to operate an open-source organizational repository.
- We are looking at migration of subversion to git.. appears possible but somewhat involved.
- If we do migrate to GitHub, that will likely complicate the re-integration of other existing subversion-based exports of Xj3D.
Maven
- Apache Maven can encourage a variety of build possibilities and paired support between multiple projects, especially for Java
Web3D.org Website
Several project builds are maintained on external repositories but their corresponding websites are automatically built and updated on web3d.org
Web3D.org home page
- TODO: have www.web3d.org/xj3d (or somesuch) provide an official summary page for Xj3D community on new web3d.org website
Mailing Lists
Web3D Consortium maintains the mailing list archives.
- Discussion list source@web3D.org is a misnomer and might be restarted as xj3d@web3d.org
- This list is also used for discussions on the SourceForge jgeom project
- Commits list source_x3d_cvs@web3d.org and commits account cvs-user@xj3d.org are also mis-named since subversion is used
Alternative approach: move all discussion and reporting lists to sourceforge. In that case, the prior email lists are simply closed and kept archived.
Upcoming tasks
Merge modified Xj3D codebases
Excellent improvements to Xj3D have occurred over the years that were never re-integrated into the version-controlled code base. We hope to capture these improvements.
- Structure And Form Analysis System (SAFAS), Nicholas Polys, Virginia Tech (VT)
- PartDB Inc., Hyokwang Lee
- Norkart/NK-VirtualGlobe, Rune Aasgaard
- Others?
Xj3D issue tracking
Currently two bugzilla sites are in existence.
- bugzilla.xj3d.org (master)
- NPS bugzilla
For maximum reliability over long term, we likely need to migrate to the native issue tracker associated with whatever source host is chosen.
Xj3D website improvements
The Xj3D website is moderately complete but woefully out of date. TODO:
- Confirm that website pages and documentation are checked into version control
- Automate website updates by synchronizing with version control
- Offer ways for people to contribute bug reports, issues, improvements
Programming problems
Several areas of Xj3D implementation are problematic. Dedicated attention and teamwork may help.
- Confirm updated jogl rendering is working, especially z-buffer and aliasing
- Extrusion
- Image rendering timing can miss colors/textures and hangs on numerous examples
- Compressed binary encoding hangs on numerous examples, but the apparent list of exception errors seems short
- Ensure that we are keeping current with JOGAMP (formerly JOGL, includes JOAL JOCL etc.) and the Aviatrix3D render layer, administered by Justin Couch
- Other project efforts are welcome
Discussion and consensus building
We are using source@web3d.org mailing list to work out these possibilities and build stakeholder consensus. (subscribe, archive)
TODO
- Describe strategy that we are re-versioning, not re-naming
- Describe how we expect to simply mirror the current repository, as version 2.0, maintaining full backwards compatibility
All inputs and contributions are welcome. Have fun with Xj3D!