ICT306 Software Architectures Assignment
Question-
Design and implement (in Java) a basic graphical user interface (GUI) program for recording information about a family tree.
You can assume that a family member has some immediate relatives: i.e., a mother and father (maybe unknown), zero or one spouses and zero or more children. A family member also has a first name, a surname at birth, a surname after marriage, a gender, an address and a paragraph of text describing what is known about their life. Obviously, this is a simplified version of reality.
An address has a street number, street name, suburb and postcode.
A family tree contains this information for a whole bunch of related people.
The program can be started in editing mode or viewing mode.
In viewing mode, the GUI shows details for one person at a time. A family tree will have a specified starting person. From the GUI the user will be able to change the displayed person to (display) one of the immediate relatives of the current person.
In editing mode, the user can choose to start a new empty family tree or edit an existing one.
A new family member can be added as an immediate relative of an existing person or the names, address, or text for an existing person can be changed. It is not necessary for this basic software to allow the user to be able to link an already existing person into a new role, e.g. as the mother of another already existing person.
The software should allow a user to conveniently enter their own family tree and have it stored for subsequent editing and viewing.
Set up a couple of demonstration family trees which you submit and give clear instructions in the User Guide on the use of those family trees.
Note that your program should compile and run under Java SE 8 and the NetBeans IDE.
Required Documentation for the Question
Please remember to submit the Java source code and executable version of your program (i.e. the whole NetBeans project).
For internal documentation (i.e. in the source code), the following is required:
- A beginning comment clearly stating title, author, date, file name, purpose and any assumptions or conditions on the form of input and expected output;
- Javadoc and other comments giving useful low-level documentation and describing each component;
- Well-formatted readable code with meaningful identifier names and blank lines between components (like methods and classes).
Required External Documentation
- Title: a paragraph clearly stating title, author, date, file names, and a one-line statement of the purpose.
- Requirements/Specification: a paragraph giving a more detailed account of what the program is supposed to do. State any assumptions or conditions on the form of input and expected output.
- User Guide: instructions on how to compile, run and use the program.
- Structure/Design: Outline the design of your program: describe why you chose one approach rather than other possible approaches. Give a written description. Describe how the classes relate to each other. Describe each class: its purpose and list of methods. Use diagrams, especially UML and STDs, and use pseudocode if you have any non-trivial algorithms. Include a complete description of the design.
- Limitations: Describe program shortfalls (if any), e.g., the features asked for but not implemented, the situations the program cannot handle etc.
- Testing: describe your testing strategy (the more systematic, the better) and any errors noticed. Provide a copy of all your results of testing in a document saved in Word format.
Note that a copy of the sample data and results from a test run of the program is required (copy from the program output window or the GUI windows and paste to the Word file).
Your submitted test results should demonstrate thorough testing of the program.
- Listings: save all your Java source code in a document in MS Word format. Note that all of the above external documentation must be included in a file saved in Word format.