Prototyping
(Created page with "Prototyping is used in all lines of engineering. Prototyping is the process were you whip something together quickly as a mock up in order to show it or test it in order to le...")
 
No edit summary
 
(11 intermediate revisions by 3 users not shown)
Line 1: Line 1:
Prototyping is used in all lines of engineering. Prototyping is the process were you whip something together quickly as a mock up in order to show it or test it in order to learn something that otherwise would be hard to know.
Used in all lines of engineering, prototyping is the process of whipping something together quickly as a mock-up to show or test to learn something that otherwise would be hard to know.


Prototyping for software has a unique position. The prototype is made up by the same stuff as the finished product ; logical rules. This is not true for any other practice of engineering. We have a unique position that we can harvest. To make the real deal – the finished product – just as easy as if we were building a prototype.
Prototyping for software has a unique position. The prototype is composed of the same elements as the finished product: logical rules. This is untrue for any other practice of engineering. We have a unique position where we can harvest to make the real deal – the finished product – just as easily as if we were building a prototype. Many experienced developers frown at this. They know how prudent you must be to build something robust and solid. They also know how quick and dirty the prototype is when you're putting it together.  


Many experienced developers will frown on this. They know how very prudent you must be to actually build something that is robust and solid. And they know how very quick and dirty they are when whipping together a prototype. Why does this big gap exists? My answer: Normal coding leaves to many degrees of freedom for the task at hand. Normal coding actually use only one tool – code – for handling data, presenting it, navigating it. Of course you will mix things up when you are in a hurry.
Why does this huge gap exist? My answer: normal coding leaves too many degrees of freedom for the task at hand. Normal coding uses only one tool – code – for handling, presenting, and navigating data. In addition, you will mix things up when you are in a hurry.


If we can separate things like the information we handle, from the transformation of that information into views and from the navigation between these views – then we have something that will almost fly on its own – and the building of the thing will be like prototyping the thing. Think of it as an autopilot it will protect you against doing stupid mistakes – it will make you fly straight – it will give you time to talk on the radio and stuff – you only need to tell it where you want to fly.
If we can separate things like the information we handle, from the transformation of that information into views and from the navigation between these views – then we have something that will almost fly on its own – and building something will be like prototyping it. Think of it as an autopilot; it will protect you against making stupid mistakes, help you fly straight, and give you time to talk on the radio or more – you only need to tell it where you want to fly.


So with MDriven we use the Model to tell the autopilot what information to handle what the perspectives of the information should be how we navigate between the views of information. Having instructed the autopilot we can take off and see if we have the right model or not. If not churn away and fix it.
With MDriven, we use the model to tell the autopilot what information to handle, what the perspectives of the information should be, and how to navigate between the views of information. Having instructed the autopilot, we can take off and see if we have the right model or not. If not, we churn away and fix it.


Many developers will also frown on the idea of an autopilot since it will emasculate them and stop them from flexing their muscles – so I need to point out that what is great with MDrivenFramework is that you can turn off the autopilot for any portion of the flight so to speak. You can still do the coolest looping in front of a gaping audience whenever you feel like it. Then turn on the autopilot to do the mundane flight back home. This will give you freedom and speed and a lot less accidents.
Many developers also frown at the idea of autopilot since it will emasculate them and stop them from flexing their muscles. I need to point out that what makes MDrivenFramework great is that you can turn off the autopilot for any portion of the flight so to speak. You can still do some cool looping in front of a gaping audience whenever you feel like it, before turning on autopilot to do the mundane flight back home. This will give you freedom, speed, and fewer accidents.


== This is how you do it with MDriven ==
== This is How You Do It With MDriven ==
1. Model what you know so far – in this example I am prototyping for a Car Rental Service
1. Model what you know so far. In the example below, I am prototyping for a Car Rental Service.
[[File:Prototyping - 1.png|none|frame|527x527px]]
[[File:Prototyping - 1.png|none|frame|527x527px]]


2. Think about what user stories or requirements you have:<blockquote>''As a Customer I want to see what cars you can rent''</blockquote><blockquote>''As a Customer I want to know what they cost per day and what my total cost will be''</blockquote><blockquote>''As a Rental worker I want to be able to hand customers rental contracts to sign''</blockquote><blockquote>''As a Rental worker I want to be able to find free cars''</blockquote>3. Then do some ViewModels that can cover these user stories – when prototyping I will make use of the scaffolding user interface hints that place out UI controls on a screen surface that match the types of the viewmodels properties. I ended up with 4 viewmodels:<blockquote>Search for a Car:</blockquote>
2. Think about what user stories or requirements you have:<blockquote>''As a Customer, I want to see what cars you can rent.''</blockquote><blockquote>''As a Customer, I want to know what they cost per day and what my total cost will be.''</blockquote><blockquote>''As a Rental worker, I want to be able to hand customers rental contracts to sign.''</blockquote><blockquote>''As a Rental worker, I want to be able to find free cars.''</blockquote>3. Then, create some ViewModels that can cover these user stories. When prototyping, make use of the scaffolding user interface hints that place out UI controls on a screen surface that matches the types of the Viewmodels properties. I end up with 4 ViewModels:<blockquote>Search for a Car:</blockquote>
[[File:Prototyping - 2.png|none|frame|478x478px]]
[[File:Prototyping - 2.png|none|frame|478x478px]]
<blockquote></blockquote><blockquote>Search for customer</blockquote>
<blockquote>Search for a Customer:</blockquote>[[File:Prototyping - 3.png|none|frame|479x479px]]
[[File:Prototyping - 3.png|none|frame|479x479px]]
<blockquote>View or edit a customer:</blockquote>
<blockquote>View or edit a customer</blockquote>
[[File:Prototyping - 5.png|none|frame|483x483px]]
[[File:Prototyping - 5.png|none|frame|483x483px]]
<blockquote>View or edit a Rental contract</blockquote>
<blockquote>View or edit a Rental contract:</blockquote>
[[File:Prototyping - 6.png|none|frame|485x485px]]
[[File:Prototyping - 6.png|none|frame|485x485px]]


4. What actions do we need to expose to the user for navigation between these views. For this I will start by clicking Create/Init standard actions in the ActionsDefinition dialog.
4. What actions do we need to expose to the user for navigation between these views? For this, start by clicking Create/Init standard actions in the ActionsDefinition dialog.


This gives me the ordinary actions like save,quit, undo and redo. It also picks up on the ViewModels I have and add some actions for them.
This gives you ordinary actions like save, quit, undo, and redo. It also picks up on the ViewModels you have and adds some actions for them.
[[File:Prototyping - 7.png|none|frame|481x481px]]
[[File:Prototyping - 7.png|none|frame|481x481px]]


I will remove the actions created for ViewAndEditCustomer and ViewAndEditRentalContract since these are rooted views that require a root object (a customer or a Rental contract) to have anything to show. Instead I add a ViewModelActions in SearchForCustomer ViewModel that creates a new Customer and one that creates new rental contracts:
Remove the actions created for ViewAndEditCustomer and ViewAndEditRentalContract since these are rooted views that require a root object (a customer or a Rental contract) to have something to show. Instead, add a ViewModelActions in the SearchForCustomer ViewModel that creates a new Customer and one that creates new rental contracts:
[[File:Prototyping - 8.png|none|frame|473x473px]]
[[File:Prototyping - 8.png|none|frame|473x473px]]


I also add class actions that can show and existing customer and rental contract
Also, add class actions that can show an existing customer and rental contract:
[[File:Prototyping - 9.png|none|frame|478x478px]]
[[File:Prototyping - 9.png|none|frame|478x478px]]


6. I could think a bit harder but the whole point with prototyping is that it should be easy to test if we are done or not. So I hit the start prototype symbol:
6. I could think a bit harder, but the whole point with prototyping is that it should be easy to test if we are done or not. So I hit the start prototype symbol:
[[File:Prototyping - 10.png|none|frame|482x482px]]
[[File:Prototyping - 10.png|none|frame|482x482px]]


I am presented with a choice on how to store data for this prototype – we will choose xml for starters:
I am presented with a choice of how to store data for this prototype. We will choose XML for starters:
[[File:Prototyping - 11.png|none|frame|408x408px]]
[[File:Prototyping - 11.png|none|frame|408x408px]]


I start the prototype and find the main menu items
I start the prototype and find the main menu items:
[[File:Prototyping - 12.png|none|frame]]
[[File:Prototyping - 12.png|none|frame]]


I pick “Search for customers” I search the system finds none I click the action new customer I get the ViewAndEditCustomer view I enter a name and save and hit back – now the search result sees a customer:
I pick “Search for customers” and I search. When the system finds none, I click the action new customer and I get the ViewAndEditCustomer view. I enter a name and save and click 'back'. Now, the search result sees a customer:
[[File:Prototyping - 13.png|none|frame]]
[[File:Prototyping - 13.png|none|frame]]


Note to self must have a Search for rental contracts
Note to self: I must have a Search for rental contracts.


I create a new rental contract – I notice that the button “Assign customer” does not do anything
I create a new rental contract and notice that the button “Assign customer” does nothing.


Note to self must bring up “search for customer on assign customer – then let user pick 1 customer and return back with it and set it on the rental contract”
Note to self: I must bring up “Search for Customer" on "Assign Customer" and let the user pick 1 customer to return back with and set them on the "rental contract”.


Note to self same for assign car – must bring up search for cars
Note to self: I must do the same for "Assign Car" and bring up "Search for cars".


Note to self I do not have any data for cars or brands and no UI to enter it – Note to self – do this in the debugger window for now
Note to self: I do not have any data for cars or brands and no UI to enter it with.


This is how a typical prototyping session goes and how it reveals obvious things we need to do. Lets do them now. Starting with using the debugger for adding cars and brands:
Note to self: I should do this in the debugger window for now.
 
This is how a typical prototyping session goes and how it reveals the obvious things we need to do. Let's do them now. Start with using the debugger for adding cars and brands:
[[File:Prototyping - 14.png|none|frame|457x457px]]
[[File:Prototyping - 14.png|none|frame|457x457px]]


I add brand as well – the save the data to the prototyping XML file by switching to dirty objects:
I add a brand as well then save the data to the prototyping XML file by switching to dirty objects:
[[File:Prototyping - 15.png|none|frame|472x472px]]
[[File:Prototyping - 15.png|none|frame|472x472px]]


I click open the Autoform of a Car-object – then I drag a Brand object to the Brand field:
I click to open the Autoform of a Car-object. I drag a Brand object to the Brand field:
[[File:Prototyping - 16.png|none|frame|533x533px]]
[[File:Prototyping - 16.png|none|frame|533x533px]]


So that takes care of test data for Cars and Brands. I still have these to items:
That takes care of test data for Cars and Brands. I still have these two items:


Note to self must bring up “search for customer on assign customer – then let user pick 1 customer and return back with it and set it on the rental contract”
Note to self: I must bring up “search for customer" on "assign customer" – then let the user pick 1 customer to return back with and set on the "rental contract”.


Note to self same for assign car – must bring up search for cars
Note to self: I must do the same for "assign car" I must bring up "search for cars".


I do this by adding a ViewModelAction for the ViewOrEditRentalContract:
I do this by adding a ViewModelAction for the ViewOrEditRentalContract:
[[File:Prototyping - 17.png|none|frame|444x444px]]
[[File:Prototyping - 17.png|none|frame|444x444px]]


The Action should bring up the search for Customer, it should be a modal action, it should be fine to press ok once a Customer is selected. And when Ok is executed we assign the picked customer to our rental contract.
The Action should bring up the search for Customer. It should be a modal action and be fine to press "ok" once a Customer is selected. When Ok is executed, we assign the picked customer to our rental contract.


The same more or less for picking a car:
The same more or less for picking a car:
[[File:Prototyping - 18.png|none|frame|425x425px]]
[[File:Prototyping - 18.png|none|frame|425x425px]]


I then choose to hook these actions up to the buttons I put in the ViewModel:
I choose to hook these actions up to the buttons I put in the ViewModel:
[[File:Prototyping - 19.png|none|frame|439x439px]]
[[File:Prototyping - 19.png|none|frame|439x439px]]


I also has this one left: Note to self – must have a Search for rental contracts
I also have this one left:  


Yet another viewmodel. Once I have it done I use the shortcut action to create global action to show it:
Note to self: I must have a Search for rental contracts.
 
Yet another ViewModel. Once I have it done, I use the shortcut action to create a global action to show it:
[[File:Prototyping - 20.png|none|frame|438x438px]]
[[File:Prototyping - 20.png|none|frame|438x438px]]


Then I press Play again:
Then I press Play again:


This time I can assign a Customer and assign a Car. The search for Car comes up in with an Ok/Cancel button because it was brought up by a modal action:
This time, I can assign a Customer and assign a Car. The search for Car comes up with an Ok/Cancel button because it was brought up by a modal action:
[[File:Prototyping - 21.png|none|frame|431x431px]]
[[File:Prototyping - 21.png|none|frame|431x431px]]


I search and pick a car and press ok:
I search, pick a car, and press ok:
[[File:Prototyping - 22.png|none|frame|460x460px]]
[[File:Prototyping - 22.png|none|frame|460x460px]]


I still have a few user stories left and I will need to change the model some, amend the viewmodels a bit, maybe create some actions. But all in all this is a very straight forward way to work. And you get instant gratification to see your model and logic come life. This is also something that triggers your ideas for further things your users will need and want. Churn on like this for an hour or two and you have done more than what you can do in a day with traditional specification work or coding.
I still have a few user stories left. I will need to change the model somewhat, amend the ViewModels a bit, and maybe create some actions. All in all, this is a very straightforward way to work. You get instant gratification when you see your model and logic come to life. This is something that will also trigger ideas for further things your users will need or want. Churn on like this for an hour or two and you will have done more than what you would do in a day with traditional specification work or coding.


== The look ==
== The Look ==
The prototyper window uses Windows Presentation Foundation (WPF) and you are free to change the used style sheet just as you see fit:
The prototyper window uses Windows Presentation Foundation (WPF). You are free to change the used style sheet as you see fit:
[[File:Prototyping - 23.png|none|frame|488x488px]]
[[File:Prototyping - 23.png|none|frame|488x488px]]


Or
Or:
[[File:Prototyping - 24.png|none|frame|493x493px]]
[[File:Prototyping - 24.png|none|frame|493x493px]]


or maybe you need to stress the that we are “just prototyping” by using something really bubbly:
Or maybe you need to stress that you are “just prototyping” by using something really bubbly:
[[File:Prototyping - 25.png|none|frame|501x501px]]
[[File:Prototyping - 25.png|none|frame|501x501px]]The MDriven Book - See: [[Training:Available Actions|Available Actions]]
 
== Available Actions ==
The actions that are shown to the left are calculated by the framework. You can have class-actions – actions associated with a class in your model. These will show up whenever an object of that class is shown in you view.
 
You can also have viewmodel actions and these only show up in the view they are defined for.
 
We have the ability to instruct the logic to do exceptions to the calculated display of actions. We can opt out the presentation of actions per view.
 
Actions may be used for navigation – but they may also perform something – like calling a method on an object.
 
In our example we already have some actions – both viewmodel actions, class actions and global actions (the ones that build up the main menu).
[[File:Prototyping - 26.png|none|frame|482x482px]]
 
Look closer at the ShowRentalContract action. This is a class action – available everywhere a RentalContract is shown. But there are situations where we do not want it to show – like when we already are in the view that is brought up by the action:
[[File:Prototyping - 27.png|none|frame|492x492px]]
 
In order to remove it we want to opt it out.
 
There are two tools in MDrivenDesigner that are good to use for this. The first one is the ViewModelEditor:
[[File:Prototyping - 28.png|none|frame|503x503px]]
 
Pressing the “>” button will move it to the opt out column:
[[File:Prototyping - 29.png|none|frame|254x254px]]
 
You can press the “<” to opt it in again.
 
The other place where you can opt out actions from is the Action Cross reference window:
[[File:Prototyping - 30.png|none|frame|464x464px]]
[[File:Prototyping - 31.png|none|frame|501x501px]]
 
In this window we see the actions that will bring this view up – currently there are 2 actions, the NewRentalContract and the ShowRentalContract.
 
We also see the actions that will show and an line to which section or nesting of the ViewModel it refers. You may click the lines and shift them from green (opt in default) to opt out. Since we already opted out our ShowRentalContract from this view – that line is already red.
 
There are also tools for looking at this from a specific actions perspective. In the ActionsEditor we see this for the ShowRentalContract Action:
[[File:Prototyping - 32.png|none|frame]]
 
It says “Action shows in 2 places. 1 Opted out” followed by a dialog button. Click that and you will see this:
[[File:Prototyping - 33.png|none|frame|523x523px]]
 
And here we see that it is opt out in the ViewAndEditRentalContract view – but it shows 2 times in the SearchForRentalContracts view. I switch back to prototyping to verify this:
[[File:Prototyping - 34.png|none|frame]]
 
And find that this is true. The reason for this is the fact that this viewmodel defines two areas that has the type RentalContract. One for the root and one for the Grid-nesting that shows the results from the variable vSeekerResult.
[[File:Prototyping - 35.png|none|frame]]
 
The root instance will always be null since this ViewModel does not require a root object to function. ViewModels designed for seeking seldom do. If it always will be null then there is little point to have an action that will be enabled only if it is assigned an object. So we should opt that root action out – click the line to toggle opt out state:
[[File:Prototyping - 36.png|none|frame|455x455px]]
 
And then the ActionEditor was updated as well:
[[File:Prototyping - 37.png|none|frame|465x465px]]
 
It now says shows in 1 place – 2 opted out.
 
I actually have had my prototyping session running all along – but it still use the model we had prior to our changes. I can now restart the prototyping by clicking play again – bringing up a new prototype window. Or I can just reread the model to the one I have:
[[File:Prototyping - 38.png|left|frame]]
 
and then I see that the ShowRentalContract action is shown only once.


If you are left alone for a day and if you have lots of ideas I promise that you can model them in MDriven designer and verify them in MDriven prototyper. When you are able to try and verify ideas rapidly you will find many “think bugs” early. Bugs that are like “oh – no – that is not a good way of doing it”. Since the MDriven environment works as your auto pilot and it has 10:th’s of thousands flight ours under its belt – you will be more free for the creative part of your work.
[[Category:Prototyping]]
[[Category:View Model]]
[[Category:MDriven Designer]]
[[Category:The MDriven Book]]

Latest revision as of 06:39, 2 April 2024

Used in all lines of engineering, prototyping is the process of whipping something together quickly as a mock-up to show or test to learn something that otherwise would be hard to know.

Prototyping for software has a unique position. The prototype is composed of the same elements as the finished product: logical rules. This is untrue for any other practice of engineering. We have a unique position where we can harvest to make the real deal – the finished product – just as easily as if we were building a prototype. Many experienced developers frown at this. They know how prudent you must be to build something robust and solid. They also know how quick and dirty the prototype is when you're putting it together.

Why does this huge gap exist? My answer: normal coding leaves too many degrees of freedom for the task at hand. Normal coding uses only one tool – code – for handling, presenting, and navigating data. In addition, you will mix things up when you are in a hurry.

If we can separate things like the information we handle, from the transformation of that information into views and from the navigation between these views – then we have something that will almost fly on its own – and building something will be like prototyping it. Think of it as an autopilot; it will protect you against making stupid mistakes, help you fly straight, and give you time to talk on the radio or more – you only need to tell it where you want to fly.

With MDriven, we use the model to tell the autopilot what information to handle, what the perspectives of the information should be, and how to navigate between the views of information. Having instructed the autopilot, we can take off and see if we have the right model or not. If not, we churn away and fix it.

Many developers also frown at the idea of autopilot since it will emasculate them and stop them from flexing their muscles. I need to point out that what makes MDrivenFramework great is that you can turn off the autopilot for any portion of the flight so to speak. You can still do some cool looping in front of a gaping audience whenever you feel like it, before turning on autopilot to do the mundane flight back home. This will give you freedom, speed, and fewer accidents.

This is How You Do It With MDriven

1. Model what you know so far. In the example below, I am prototyping for a Car Rental Service.

Prototyping - 1.png

2. Think about what user stories or requirements you have:

As a Customer, I want to see what cars you can rent.

As a Customer, I want to know what they cost per day and what my total cost will be.

As a Rental worker, I want to be able to hand customers rental contracts to sign.

As a Rental worker, I want to be able to find free cars.

3. Then, create some ViewModels that can cover these user stories. When prototyping, make use of the scaffolding user interface hints that place out UI controls on a screen surface that matches the types of the Viewmodels properties. I end up with 4 ViewModels:

Search for a Car:

Prototyping - 2.png

Search for a Customer:

Prototyping - 3.png

View or edit a customer:

Prototyping - 5.png

View or edit a Rental contract:

Prototyping - 6.png

4. What actions do we need to expose to the user for navigation between these views? For this, start by clicking Create/Init standard actions in the ActionsDefinition dialog.

This gives you ordinary actions like save, quit, undo, and redo. It also picks up on the ViewModels you have and adds some actions for them.

Prototyping - 7.png

Remove the actions created for ViewAndEditCustomer and ViewAndEditRentalContract since these are rooted views that require a root object (a customer or a Rental contract) to have something to show. Instead, add a ViewModelActions in the SearchForCustomer ViewModel that creates a new Customer and one that creates new rental contracts:

Prototyping - 8.png

Also, add class actions that can show an existing customer and rental contract:

Prototyping - 9.png

6. I could think a bit harder, but the whole point with prototyping is that it should be easy to test if we are done or not. So I hit the start prototype symbol:

Prototyping - 10.png

I am presented with a choice of how to store data for this prototype. We will choose XML for starters:

Prototyping - 11.png

I start the prototype and find the main menu items:

Prototyping - 12.png

I pick “Search for customers” and I search. When the system finds none, I click the action new customer and I get the ViewAndEditCustomer view. I enter a name and save and click 'back'. Now, the search result sees a customer:

Prototyping - 13.png

Note to self: I must have a Search for rental contracts.

I create a new rental contract and notice that the button “Assign customer” does nothing.

Note to self: I must bring up “Search for Customer" on "Assign Customer" and let the user pick 1 customer to return back with and set them on the "rental contract”.

Note to self: I must do the same for "Assign Car" and bring up "Search for cars".

Note to self: I do not have any data for cars or brands and no UI to enter it with.

Note to self: I should do this in the debugger window for now.

This is how a typical prototyping session goes and how it reveals the obvious things we need to do. Let's do them now. Start with using the debugger for adding cars and brands:

Prototyping - 14.png

I add a brand as well then save the data to the prototyping XML file by switching to dirty objects:

Prototyping - 15.png

I click to open the Autoform of a Car-object. I drag a Brand object to the Brand field:

Prototyping - 16.png

That takes care of test data for Cars and Brands. I still have these two items:

Note to self: I must bring up “search for customer" on "assign customer" – then let the user pick 1 customer to return back with and set on the "rental contract”.

Note to self: I must do the same for "assign car" – I must bring up "search for cars".

I do this by adding a ViewModelAction for the ViewOrEditRentalContract:

Prototyping - 17.png

The Action should bring up the search for Customer. It should be a modal action and be fine to press "ok" once a Customer is selected. When Ok is executed, we assign the picked customer to our rental contract.

The same more or less for picking a car:

Prototyping - 18.png

I choose to hook these actions up to the buttons I put in the ViewModel:

Prototyping - 19.png

I also have this one left:

Note to self: I must have a Search for rental contracts.

Yet another ViewModel. Once I have it done, I use the shortcut action to create a global action to show it:

Prototyping - 20.png

Then I press Play again:

This time, I can assign a Customer and assign a Car. The search for Car comes up with an Ok/Cancel button because it was brought up by a modal action:

Prototyping - 21.png

I search, pick a car, and press ok:

Prototyping - 22.png

I still have a few user stories left. I will need to change the model somewhat, amend the ViewModels a bit, and maybe create some actions. All in all, this is a very straightforward way to work. You get instant gratification when you see your model and logic come to life. This is something that will also trigger ideas for further things your users will need or want. Churn on like this for an hour or two and you will have done more than what you would do in a day with traditional specification work or coding.

The Look

The prototyper window uses Windows Presentation Foundation (WPF). You are free to change the used style sheet as you see fit:

Prototyping - 23.png

Or:

Prototyping - 24.png

Or maybe you need to stress that you are “just prototyping” by using something really bubbly:

Prototyping - 25.png

The MDriven Book - See: Available Actions

This page was edited more than 9 months ago on 04/02/2024. What links here