Difference between revisions of "Professional development/Design thinking/Software prototyping and tools"

From CEED Wiki
Jump to navigation Jump to search
m
Line 92: Line 92:
  
 
===Apple development===
 
===Apple development===
It is more complicated to develop apps for iPhone or Mac then for Android or Windows. You can get an [https://developer.apple.com/programs/ 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 make it a very feasible choice for a semester-long project.
+
It is more complicated to develop apps for iPhone or Mac then for Android or Windows. You can get an [https://developer.apple.com/programs/ 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 [https://en.wikipedia.org/wiki/Progressive_web_application 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:
 
It is recommended to make [https://en.wikipedia.org/wiki/Progressive_web_application 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
 
*What are PWA's: https://www.youtube.com/watch?v=4XT23X0Fjfk
*Tutorial with HTML and javascript:
+
*Codebase for building PWAs:
**https://medium.com/james-johnson/a-simple-progressive-web-app-tutorial-f9708e5f2605
+
**[https://angular.io/ Angular] PWA guide- https://angular.io/guide/service-worker-getting-started
**https://dzone.com/articles/how-to-build-a-progressive-web-app-pwa-with-javasc
+
**[https://reactjs.org/ React] PWA guide- https://create-react-app.dev/docs/making-a-progressive-web-app/
**https://web.dev/progressive-web-apps/
+
**[https://nextjs.org/ Next] PWA guide- https://github.com/vercel/next.js/tree/canary/examples/progressive-web-app
*Convert web application to PWA: https://www.creativebloq.com/how-to/build-a-progressive-web-app
+
**HTML and javascript PWA tutorials
*Convert wix site to PWA: https://wappaa.com/wappstore/wix-site-to-app/
+
***https://medium.com/james-johnson/a-simple-progressive-web-app-tutorial-f9708e5f2605
 +
***https://dzone.com/articles/how-to-build-a-progressive-web-app-pwa-with-javasc
 +
***https://web.dev/progressive-web-apps/
 +
*One option is AWS (Amazon web services) as the framework for hosting the PWA
 +
**Create an [https://aws.amazon.com/s3/pricing/ S3 bucket] for each project -> free, almost, might cost a couple of cents a month 
 +
**[https://aws.amazon.com/route53/pricing/ Route 53] to create the subdomains -> free 
 +
**[https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/domain-register.html#domain-register-procedure Domains] -> to buy the domain for the class, might be $15 a year (not necessary for GNG)
 +
**[https://aws.amazon.com/certificate-manager/ Certificates] -> free to get the ssl certificate 
 +
**[https://github.com/pricing GIthub] for hosting code and publishing to S3-> Free
 
*Tools for building PWA's:  
 
*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://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://developers.google.com/web/updates/2015/12/getting-started-pwa

Revision as of 20:26, 17 October 2021

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.

Here is a list of platforms that require minimal coding experience to use:

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: