The minimum requirements for the project are outlined here to give you a starting point. Meeting the minimum requirements alone will not guarantee you a good mark. You are welcome to meet and exceed the minimum requirements if you have good, creative ideas and would like to discuss them with me.
Requirement 1: The project must incorporate some visual interface using Processing.org libraries. All user interaction must be conducted via this interface.
Requirement 2: The project must incorporate some kind of non-blocking concurrent/asynchronous processing that happens at regular intervals. For example, you might push or fetch data from in the background.
Requirement 3: The project must incorporate some kind of non-trivial persistent data state that must be read, processed, and written at regular intervals. For example, you might save a game state in a JSON file. This may or may not be included with Requirement 2.
Requirement 4: The project must incorporate some kind of self-managing custom iterable data structure. For example, you might have a collection of enemies that are added and deleted based on statistics maintained by the data structure.
Requirement 5: The project must be well-documented, complete, and run without errors on final submission.
The project pitch will be a short document that describes the kind of interactive application you would like to create with your group. The project pitch must include the following items:
One-liner: One-sentence description of your project. Outline: 1-10 sentences that describe how your project will fulfill the project requirements. Communication policies: A description of how your group will meet, communicate, and make decisions (as per Lab 03). Roles and responsibilities: A description of each team member's jobs in the group. Milestones: A rough outline of the major project milestones that you expect to complete and your own estimated timeline. This can and will change, so do your best to estimate and plan for the milestones to change.
Draft was due today, final due next lab. Submission here, on GitHub. Make a .md
file that outlines the above.
The initial UML diagrams will outline the class structure that your group will follow for the first milestone of the project. It must include the following items all classes that will be created by the group and important descriptive interfaces from either the Java library or created by the group. I expect that this will change significantly throughout the project, so it does not have to be perfect but it should be a best effort attempt. This is because you will use this to communicate with your group members about what to make. Therefore, the diagram should be sufficiently complex to give you a term's worth of work.
Draft due next Lab, final due two labs from now. Submission here, on GitHub. Suggestion is to use a tool like draw.io but you may use whatever tool is most useful for you.
The initial GitHub issues will be the tasks that are assigned to each of your group members at the beginning of the project. Every team member should have at least five issues to start (20-30 total). You will have to decide within your group how granular you want to make these issues.
Issues will be tracked here, on GitHub.
The Final Project Demo will be a working version of your project that you will present to your lab section for review. The demo will be in lab, and will include a live demo of the working application, and a short code review. There are no slides required, but you should have practiced your demo to make sure it will run reasonably well. This will be during the last lab of class.
No submission.
The Final README.md must give instructions on how to run your program, a list of contributions by each member, and any references/citations for code you may have used from elsewhere.
Submission is here, on GitHub, in the README.md
file.
The Final Product will be evaluated for overall code design and documentation and evaluated on the same design principles as individual contributions. If you are below the 1000 line minimum contribution, your mark will be scaled down for this portion.
Submission is here, on GitHub.
You will be expected to take on a significant individual contribution to the group project (at least 1000 lines of non-trivial code). It may be in a number of forms, but here are some examples:
Architect: you are in charge of the high-level code structuring and organizing.
Test maker: you are in charge of test coverage that supports other group members.
UI/UX lead: you design and implement the user interface.
Backend: you design and implement the data structures.
…??: Make up your own depending on your use case, i.e., collision system designer, animation architect, async code wrangler.
Contributions must be for functional, working Java code and must be continuous throughout the term. You may not, for example, push all of your changes at the end of term. Code will be marked on following good design principles, i.e., SOLID, design patterns, etc. You are encouraged to work together and use pair programming for components, but you will be marked on your contribution to your own modules individually.
Your code must be well-documented with fully-formed method signatures, comments, and necessary README or Wiki pages. This is further broken down into the following.
A description of your individual feature that you plan to implement.
Due date TBD.
Any combination of sequence, communcation, or class diagrams that describe your feature's initial planned abilities.
Due date TBD.
Your personal feature documentation, wherever it happens to show up in the final documentation.
Due with final submission.
You must track your own work in the form of creating and closing GitHub issues, creating and reviewing pull requests, responding to issues that have been assigned to you, and creating issues that you assign to others (all within reason).
The project MUST be managed here, in this GitHub repo. Nothing that happens outside of this GitHub repo will be trackable by me, therefore, it will not be marked or considered for marking.
You must use the following branching structures:
main
branch must always be working, tested, debugged, human-readable code.<initals>_<issue #>_<optional description>
is the format for each ISSUE that you're working on. It should always be a branch off ofmain
.- Every individual branch must regularly merge
main
, and it should be no more than a few days before your branch is either merged intomain
or deleted.
You must use pull requests to manage your code integration:
- make your branch from
main
, e.g.,git checkout -b pb_71_demo
- make your commits, e.g.,
git add .
andgit commit -m "fixed issue 71 by reloading gradle for the 100th time"
andgit push origin pb_71_demo
. - merge
main
into your branch, and NOT the other way around. E.g.,git merge main
. YOU fix all the merge conflicts or problems that arise. Commit and push again. - go to GitHub.com and make a pull request
- one other person (NOT YOU) needs to review the code and either approve or reject your changes with detailed line-by-line comments.
- If needed, make the requested fixes and commit and push again.
- the other person (NOT YOU) will merge your PR into
main
- the other person (NOT YOU) will delete your branch