Professional development/Design thinking/Software prototyping and tools
Many of us (TAs/PMs and students) struggle with the concept of testing software or just how to prototype software. It is less concrete than physical prototyping and is harder to wrap your head around. You might say that you can’t test or can’t prototype something because it is software...think again!
We’ll compare it to a typical mechanical design cycle (not considering client involvement):
Design step | Mechanical | Software |
Conceptual designs | Hand/computer drawn sketches | Hand/computer drawn sketches |
Preliminary design | Rough CAD assemblies | Wireframe designs/flowchart |
Detailed design | Fully defined CAD | High fidelity mockup/Initial coded software |
Simulation/testing | CAD force/fluid simulations | UX simulation |
Prototype 1 | Manufactured part(s) | Functional coded software |
Refined testing | Testing under load against metrics | Sub functions to test behavior of specific features against metrics |
In our GNG1103/2101 classes the cycle looks a little differently where you might have:
Design step | Mechanical | Software |
Conceptual designs | Hand drawn sketches | Hand drawn sketches |
Detailed design | Detailed sketches of sub-assemblies with some analysis | Wireframe designs/flowchart |
Prototype 1 | Cardboard prototype | High fidelity mockup/Initial coded software |
Simulation/testing | Functional testing of prototype against metrics | UX simulation against metrics |
Prototype 2/3 | Assembled and functional prototype | Functional software |
Here are some metrics that might be useful for you https://www.nngroup.com/articles/usability-metrics/.
Sharing
When working in a team you will definitely want to share your files to work on things together. In mechanical GrabCad Workbench is a popular tool but in software GitHub is definitely an industry standard.
Here is an introduction to GitHub https://guides.github.com/activities/hello-world/
Tools
Here is a list of tools for UI and UX prototyping that could be useful and are very easy to use: https://blog.prototypr.io/top-20-prototyping-tools-for-ui-and-ux-designers-2017-46d59be0b3a9 (Figma, Balsamiq and Adobe XD are suggested which are free or free for students). Draw.io is also useful for flowcharts.
Ensure that when you design your UI for clients having accessibility needs, you take into considerations the colours you use.
- This website and this website based on the Web Content Accessibility Guidelines (WCAG) is a great resource that was suggested by a client who works in accessibility!
- This website also has great infographics for dos and don'ts on designing for different accessibility groups.
- This University of Sussex page with a few pre-loaded colours can be a very useful tool for this as well. Notice how the uOttawa official backdrop colour scores well with white text.
- This website allows you to upload a picture and see it though the eyes of someone with color blindness.
Here is a list of platforms that require minimal coding experience to use:
- MIT app inventor (android apps only)
- Thunkable (android and iOS apps)
- Adalo (android and iOS apps, more limited then thunkable)
- Wix (website)
- Microsoft Power Apps (android, iOS and windows)
Here is a list of useful websites with code syntax and libraries which can help you get started:
- W3 Schools (HTML, CSS, JavaScript, SQL, PHP and more!)
Here is a list of other platforms for building apps or websites which you would need more coding experience to use:
Apple development
It is more complicated to develop apps for iPhone or Mac then for Android or Windows. You can get an Apple developer account which allows you to publish to the Apple store or to Test Flight however it costs 99$ USD/year. Publishing to these platforms also entails rigorous testing and must abide by Apple's high standards which does not usually make it a very feasible choice for a semester-long project.
It is recommended to make progressive web apps(PWA) when developing for Apple devices. These websites are able to be 'installed' on phones as if they were apps and there is a lot of documentation on it. Here are a few resources to get you started:
- What are PWA's: https://www.youtube.com/watch?v=4XT23X0Fjfk
- Codebase for building PWAs:
- Angular PWA guide- https://angular.io/guide/service-worker-getting-started
- React PWA guide- https://create-react-app.dev/docs/making-a-progressive-web-app/
- Next PWA guide- https://github.com/vercel/next.js/tree/canary/examples/progressive-web-app
- HTML and javascript PWA tutorials
- One option is AWS (Amazon web services) as the framework for hosting the PWA
- Create an S3 bucket for each project -> free, almost, might cost a couple of cents a month
- Route 53 to create the subdomains -> free
- Domains -> to buy the domain for the class, might be $15 a year (not necessary for GNG)
- Certificates -> free to get the ssl certificate
- GIthub for hosting code and publishing to S3-> Free
- Tools for building PWA's:
- Convert web application to PWA: https://www.creativebloq.com/how-to/build-a-progressive-web-app
- Convert wix site to PWA: https://wappaa.com/wappstore/wix-site-to-app/
- https://techbeacon.com/app-dev-testing/5-best-tools-building-progressive-web-apps-fast
- https://developers.google.com/web/updates/2015/12/getting-started-pwa
- https://developer.mozilla.org/en-US/docs/Web/Progressive_web_apps