Thursday, August 26, 2010
Visual Studio 2010
Taking the big step of moving to VS2010/Silverlight 4 today. I've been using VS2008 with Silverlight 3 for some time now. Upgrading is always fraught with danger. Will the third party components I use still work properly? Will my code still compile? However, there are enough new features in Silverlight 4 to make the effort worthwhile. Here's hoping for a smooth transition...
Thursday, May 13, 2010
thepowertool powers on
Well, we've been doing lots of demos for thepowertool. We've concentrated on the legal firms, who handle construction companies and disputes, and building associations. We need their endorsement so that if someone asks 'have you heard of thepowertool?' they can immediately say 'yes, its great!'. So far their support has been overwhelmingly postive, which bodes well for the future. Now we turn our focus to actual sign ups!
Tuesday, April 20, 2010
thepowertool is live
Over the last six months we've been working on a new product called thepowertool and we've just gone live. thepowertool is a construction payment system which links the claimant (the company wanting to be paid) with the respondent (the one doing the paying). The claimant uses our browser-based Silverlight program to define their clients and contracts. Each month they will create a payment claim which is emailed to the respondent. The respondent can click on the email link to approve/adjust the payment claim. The system provides the easiest way yet for claimants and respondents to process payment claims using a strict process that conforms to the security payments legislation which has been introduced in most Australian states, New Zealand, Malaysia and Singapore.
For any project to be successful you need the right mix of people. We've provided our technical expertise while others have provided their expertise in the construction industry and the application of the legislation. We've been showing it off to a number of industry bodies and they are very excited by what they have seen. I think we have a winner here!
For any project to be successful you need the right mix of people. We've provided our technical expertise while others have provided their expertise in the construction industry and the application of the legislation. We've been showing it off to a number of industry bodies and they are very excited by what they have seen. I think we have a winner here!
Thursday, April 15, 2010
C'mon Steve!
The battle between Apple and Adobe is heating up with some collateral damage. With Adobe about to release CS5 with a Flash-to-iPhone compiler, which would have flooded the app store with tons of crappy flashware apps (to match the tons of crappy Objective-C apps), Apple have made a change to their developer agreement. Section 3.3.1 now states programs must be 'originally written' with Objective C or C++. No Flash. So much for Adobe spending all that money on their compiler technology. Unfortunately, the same clause prevents programs being written in Monotouch, Unity3D and a number of other similar languages.
Various reasons have been suggested for the change:
-Programs won't play nice with the new multi-tasking in OS4.0. Pity one of the programs Steve Jobs specifically demonstrated at the OS 4.0 release was written in one of these now banned languages.
-Cross-platforms apps don't provide the look and feel of the native apps. Monotouch used the specific Cocoa API's provided for the iPhone to generate the UI. So its UI is exactly the same as apps generated using Objective-C. And games don't count since they have their own UI anyway.
-Relying on another layer between the Apple API's and other tools will slow down the adoption of new API's. Monotouch had a new version out supporting the new iPad API's within 24 hours of the dev-kit being released by Apple.
If Microsoft tried to pull this same crap, there would be a massive uproar. But it seems its ok for Apple to do it. It might be argued that Microsoft has a monopolistic grasp on the PC market that Apple doesn't have. But in terms of smart phone applications it could easily be argued that iPhone has the dominance and near monopoly. And it looks like they will do all they can to keep it that way.
Basically the only good reason I've heard so far has been that Uncle Steve wants to lock developers into developing for the iPhone. A cross-platform tool can make it too easy to develop an app for multiple phones. Having the same app appear on different app stores simultaneously dilutes the value of the iTunes app store.
In general, I'm quite happy to be developing just for the iPhone - the handsets seem to be everywhere. This latest move by Apple leaves a sour taste though. I would have preferred to be working on iPhones because they were simply the best not because Apple put up artificial technical obstacles to limit competition.
And it would be easier to live with, if Apple actually updated Objective-C to have many of the features modern languages have. In my opinion, Objective-C doesn't really cut it. Our first couple of apps were using Objective-C, so we have some idea what we are doing. However, using MonoTouch provided a big improvement in productivity, especially when the app links to a web back-end using C#.
For the moment, we'll be watching events unfold over the next couple of weeks before making a decision on what we do with the tools. Our apps won't be too hard to back port to Objective-C, I'll just miss memory-management, a decent XML parser, Linq, etc.
Interesting times...
Various reasons have been suggested for the change:
-Programs won't play nice with the new multi-tasking in OS4.0. Pity one of the programs Steve Jobs specifically demonstrated at the OS 4.0 release was written in one of these now banned languages.
-Cross-platforms apps don't provide the look and feel of the native apps. Monotouch used the specific Cocoa API's provided for the iPhone to generate the UI. So its UI is exactly the same as apps generated using Objective-C. And games don't count since they have their own UI anyway.
-Relying on another layer between the Apple API's and other tools will slow down the adoption of new API's. Monotouch had a new version out supporting the new iPad API's within 24 hours of the dev-kit being released by Apple.
If Microsoft tried to pull this same crap, there would be a massive uproar. But it seems its ok for Apple to do it. It might be argued that Microsoft has a monopolistic grasp on the PC market that Apple doesn't have. But in terms of smart phone applications it could easily be argued that iPhone has the dominance and near monopoly. And it looks like they will do all they can to keep it that way.
Basically the only good reason I've heard so far has been that Uncle Steve wants to lock developers into developing for the iPhone. A cross-platform tool can make it too easy to develop an app for multiple phones. Having the same app appear on different app stores simultaneously dilutes the value of the iTunes app store.
In general, I'm quite happy to be developing just for the iPhone - the handsets seem to be everywhere. This latest move by Apple leaves a sour taste though. I would have preferred to be working on iPhones because they were simply the best not because Apple put up artificial technical obstacles to limit competition.
And it would be easier to live with, if Apple actually updated Objective-C to have many of the features modern languages have. In my opinion, Objective-C doesn't really cut it. Our first couple of apps were using Objective-C, so we have some idea what we are doing. However, using MonoTouch provided a big improvement in productivity, especially when the app links to a web back-end using C#.
For the moment, we'll be watching events unfold over the next couple of weeks before making a decision on what we do with the tools. Our apps won't be too hard to back port to Objective-C, I'll just miss memory-management, a decent XML parser, Linq, etc.
Interesting times...
Thursday, January 14, 2010
An Exciting New Year
Well its back into it for a new year. 2010 already! Where did that decade go?
It was quite a long break over December and I'm all nice and refreshed. Clients are just starting to get back into work mode so we should see some things ramp up. My Delphi work continues to pay the bills. I've been working for a client adding functionality to a shed design system. Quite a bit different from retail. Lots of number crunching and engineering. Makes for a nice change!
There are some other projects in the pipeline which I should be able to blog about soon. We are aiming to launch a new system in late February. This is a mixed Silverlight/ ASP.NET MVC project I have been working on over the last few months (as time permits). It should be quite exciting as we believe its got some good potential. I've quite enjoyed working with these newer technologies. Silverlight took some getting used to and I had to pull a framework together for it, but I've got a system I am pretty happy to put my name to. If it works out as expected, there will also be some iPhone integration added later on, which will add more value to the system.
There is also another Silverlight/iPhone project I am working on. This one is early days but there seems to be some interest in it. If we can translate that into some funding, work will start on it soon.
Speaking of iPhone, I'm looking to change from Objective C to Monotouch. I've found Objective C to be ok to work with (although memory management is a bit of a pain). As a techie its always nice to learn new stuff. So why change? Monotouch provides a C# programming model for iPhones. What it means is I can consolidate the languages I'm using at the moment to Delphi and C#. I also get nice things like memory management and Linq and I can share business logic/ code across my iPhone/Silverlight/ASP.NET apps. Cool!
Looking forward to a big 2010!
It was quite a long break over December and I'm all nice and refreshed. Clients are just starting to get back into work mode so we should see some things ramp up. My Delphi work continues to pay the bills. I've been working for a client adding functionality to a shed design system. Quite a bit different from retail. Lots of number crunching and engineering. Makes for a nice change!
There are some other projects in the pipeline which I should be able to blog about soon. We are aiming to launch a new system in late February. This is a mixed Silverlight/ ASP.NET MVC project I have been working on over the last few months (as time permits). It should be quite exciting as we believe its got some good potential. I've quite enjoyed working with these newer technologies. Silverlight took some getting used to and I had to pull a framework together for it, but I've got a system I am pretty happy to put my name to. If it works out as expected, there will also be some iPhone integration added later on, which will add more value to the system.
There is also another Silverlight/iPhone project I am working on. This one is early days but there seems to be some interest in it. If we can translate that into some funding, work will start on it soon.
Speaking of iPhone, I'm looking to change from Objective C to Monotouch. I've found Objective C to be ok to work with (although memory management is a bit of a pain). As a techie its always nice to learn new stuff. So why change? Monotouch provides a C# programming model for iPhones. What it means is I can consolidate the languages I'm using at the moment to Delphi and C#. I also get nice things like memory management and Linq and I can share business logic/ code across my iPhone/Silverlight/ASP.NET apps. Cool!
Looking forward to a big 2010!
Saturday, October 31, 2009
WPF And Multiple CollectionViews With Filtering
This one drove me nuts for a bit. You can have multiple views against a single data set. So if you have:
ObservableCollection orders;
you could have one view for Late Orders, another view for New Orders, etc.
You do this using collectionviews. However most of the examples you find show something like this:
ListCollectionView view = (ListCollectionView)CollectionViewSource.GetDefaultView(orders);
However, if you create multiple views like this on orders, you will actually still be working off the default view. If you put a filter on one view, that will actually apply to all views. You need to create the view like this:
ListCollectionView view = new ListCollectionView(orders);
Then you can apply filtering to that view without affecting other views.
ObservableCollection
you could have one view for Late Orders, another view for New Orders, etc.
You do this using collectionviews. However most of the examples you find show something like this:
ListCollectionView view = (ListCollectionView)CollectionViewSource.GetDefaultView(orders);
However, if you create multiple views like this on orders, you will actually still be working off the default view. If you put a filter on one view, that will actually apply to all views. You need to create the view like this:
ListCollectionView view = new ListCollectionView(orders);
Then you can apply filtering to that view without affecting other views.
Tuesday, August 25, 2009
ASP.NET MVC Numeric Textbox
Introduction
So I've been having a bit of a look at ASP.NET MVC as part of the public facing section of the Silverlight project I am working on. I've been able to get running the main part but wanted to neaten up the validation. I wanted to be able to add a TextBox on my form that would only accept a number. From what I could see jquery was the way to go. (If you have a look here you can see an example of how the numeric entry works.) But that raised a number of questions:
Using Google it took quite a bit of time to track down all the pieces to make this work. As a result, I've written this one post that hopefully brings it together.
Making A Head Content Available
In order to use jQuery, you need to be able to add some scripts to the page generated by the view. This really needs to be in the head section, but on my view pages, there was no where to add it. I had an asp:content tag for TitleContent and one for MainContent but nothing where I could put the script.
In the Site.Master page I modified the head section from this:
To this:
See the ContentPlaceHolder? That will allow me to define a head section in my view pages.
Adding The Scripts
Now that I have a ContentPlaceHolder, I can edit my view pages to add scripts. Just below the Page command I can add the code that will appear in the head section of the page.
Few things to note here:
Making A TextBox Numeric
The last part is to create a TextBox in the view that needs to be numeric entry only. In my case I used code like this:
This is basically just creating a textbox on the form. The magic that pulls all this together is the clause:
This links it back to the input.numeric reference in the script and the textbox will be limited to a numeric. You can have as many textboxes on the form as you require and provided you include the '@class="numeric" ' part, they will all be numeric entry only.
You can set the textboxes up by id if you want. So in the ready function you would have this:
In this case, the # means treat the following word as the id of the textbox, not the class. You have to specify each one.
Then on the textbox you would have:
Note, I didn't set the @class this time, I set the id.
Conclusion
Its actually pretty easy to get the numeric textbox working once you know all the pieces. Hopefully, someone finds this useful!
So I've been having a bit of a look at ASP.NET MVC as part of the public facing section of the Silverlight project I am working on. I've been able to get running the main part but wanted to neaten up the validation. I wanted to be able to add a TextBox on my form that would only accept a number. From what I could see jquery was the way to go. (If you have a look here you can see an example of how the numeric entry works.) But that raised a number of questions:
- How to use jQuery?
- How to add scripts?
- How to add the TextBox?
- How to specify the class of a TextBox?
Using Google it took quite a bit of time to track down all the pieces to make this work. As a result, I've written this one post that hopefully brings it together.
Making A Head Content Available
In order to use jQuery, you need to be able to add some scripts to the page generated by the view. This really needs to be in the head section, but on my view pages, there was no where to add it. I had an asp:content tag for TitleContent and one for MainContent but nothing where I could put the script.
In the Site.Master page I modified the head section from this:
<head runat="server">
<title><asp:ContentPlaceHolder ID="TitleContent" runat="server" /></title>
<link href="../../Content/Site.css" rel="stylesheet" type="text/css" />
</head>
To this:
<head runat="server">
<title><asp:ContentPlaceHolder ID="TitleContent" runat="server" /></title>
<link href="../../Content/Site.css" rel="stylesheet" type="text/css" />
<asp:ContentPlaceHolder ID="head" runat="server" />
</head>
See the ContentPlaceHolder? That will allow me to define a head section in my view pages.
Adding The Scripts
Now that I have a ContentPlaceHolder, I can edit my view pages to add scripts. Just below the Page command I can add the code that will appear in the head section of the page.
<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<Construction.Service.Claim>" %>
<asp:Content ID="Scripts" ContentPlaceHolderID="head" runat="server" >
<script src="/Scripts/jquery-1.3.2.min.js" type="text/javascript"></script>
<script type="text/javascript" src="/Scripts/jquery.numeric.pack.js"></script>
<script type="text/javascript">
$(document).ready(function() {
$("input.numeric").numeric();
});
</script>
</asp:Content>
Few things to note here:
- Everything in the asp:Content ID="Scripts" section will appear in the head section on the generated page. Just what I wanted.
- In the scripts I've added reference to "/Scripts/jquery-1.3.2.min.js". This is the jQuery library that ships with ASP.NET MVC V1.0.
- The next line is for "/Scripts/jquery.numeric.pack.js". This tells the page that we want to use the jquery numeric library which can be found here. I downloaded this file and then added it to the scripts section of my project. This line in my head section references that file. That link shows the jQuery numeric usage. So once you have this basic one going, you can refer back to that link to see how you might extend your options.
- The next part is the 'ready' function for jQuery. I'm new to jQuery but from what I can work out, this is the function where you put all your stuff to prepare things for later use. In this case we are telling the system that things identified as 'input.numeric' will be numeric. The 'input' simply refers to the fact this will be associated to an input textbox. The '.numeric' indicates that this will be used by any input control that is of *class* 'numeric'. We'll see how this works next.
Making A TextBox Numeric
The last part is to create a TextBox in the view that needs to be numeric entry only. In my case I used code like this:
<%= Html.TextBox("ApprovedPercentage, ViewData.Model.ApprovedPercentage,
new { size = "5" ,@class="numeric" })%>
This is basically just creating a textbox on the form. The magic that pulls all this together is the clause:
@class="numeric"
This links it back to the input.numeric reference in the script and the textbox will be limited to a numeric. You can have as many textboxes on the form as you require and provided you include the '@class="numeric" ' part, they will all be numeric entry only.
You can set the textboxes up by id if you want. So in the ready function you would have this:
$(document).ready(function() {
$("input#approvedpercentage").numeric();
$("input#approvedamount").numeric();
});
In this case, the # means treat the following word as the id of the textbox, not the class. You have to specify each one.
Then on the textbox you would have:
<%= Html.TextBox("ApprovedPercentage, ViewData.Model.ApprovedPercentage,new { size = "5" ,id="approvedpercentage" })%>
Note, I didn't set the @class this time, I set the id.
Conclusion
Its actually pretty easy to get the numeric textbox working once you know all the pieces. Hopefully, someone finds this useful!
Subscribe to:
Posts (Atom)