5,401,186 members and growing! (293 online)
Email Password   helpLost your password?
Platforms, Frameworks & Libraries » Mobile Development » Applications     Intermediate License: The Code Project Open License (CPOL)

End-to-End Real World BlackBerry Application, Part 2

By MiamiCoder

End-to-End Real World BlackBerry Application Walkthrough 2
Java, C# 2.0, C#, Java, Mobile (Mobile, Blackberry), .NET, .NET 2.0VS2005, Visual Studio, Architect, Dev, Design

Posted: 25 Jun 2008
Updated: 15 Jul 2008
Views: 3,499
Bookmarked: 7 times
Announcements
Want a new Job?



Search    
Advanced Search
Sitemap
votes for this Article.
Popularity: 0.00 Rating: 0.00 out of 5
Note: This is an unedited contribution. If this article is inappropriate, needs attention or copies someone else's work without reference then please Report This Article

Introduction

In the first article of this series I started walking you through the creation of an end-to-end BlackBerry application that will serve as a mobile front-end to my Knowledge Base sample web application.

The requirements for the mobile application are pretty simple:

  1. Searching a collection of articles stored in a knowledge base repository, by title or tags
  2. View an article. The article’s visible attributes are: title, body, tags, author’s name, date published

And my building blocks look like this:

Building-Blocks1.gif

Implementation

Previously, I finished the Application Class and the Home Screen

Home-Screen1.gif

I will continue now with the rest of the screens.

Tags Screen

The Tags Screen displays a list of the existing tags in the database. Beside each tag there will be a count of the articles the tag applies to.

Tags-Screen1.gif

Search Screen

This screen will allow our users to initiate an articles search by typing one or more words belonging to the article’s title.

Search-Screen1.gif

The searchArticles() function is present in both the Tags Screen and the Search Screen and so far it only pushes the Articles Screen to the top of the stack. Later I will add the code that will request my server-side handler to issue the database query and return any results.

    private void searchArticles() {
        String searchPhrase = searchPhraseField.getText().trim();
        if (null != searchPhrase && searchPhrase.length() > 0) {
            UiApplication.getUiApplication().pushScreen(articlesScreen);
            // TODO: Trigger the search function in the Articles Screen. 
        } else {
            Dialog.alert("You must enter a search phrase.");
        }
    }


Articles Screen

The Articles Screen shows a list of articles that satisfy the criteria entered on the Search Screen. It can also show a list of recently viewed articles. Clicking on any listed article will bring the Article Screen to the top of the stack.

Articles-Screen1.gif

Since I’m still missing the network routines, I created a few dummy articles in order to test the look and feel of the Articles Screen:

    ArticlesScreen() {
        
        this.setTitle("Articles");
        
        // Create a few dummy tags in order to test the screen;
        articles = new Article[15];
        Article article;
        for (int i = 0; i < 15; i++) {
            article = new Article();
            article.title = "Dummy article " + Integer.toString(i);
            article.author = "ramonj";
            article.contents = "This is a test article";
            article.tags = new String[] {"tag 1", "tag 2", "tag 3"};
            article.dateCreated = "01/01/2008";
            articles[i] = article;
        }
        
        articlesList = new ArticlesListField();
        articlesList.set(articles);
        this.add(articlesList);
        
    }

The Article Class is shown below. Note that I’m not paying a lot of attention to encapsulation, since the usage of this class will be restricted to only a few places in the application.

class Article {
    public String title;
    public String dateCreated;  
    public String author;
    public String[] tags;
    public String contents;
}


Article Screen

The Article Screen shows the viewable attributes of the article that was selected on the Articles Screen. This is where the user get’s to read the article. This is another place where I use the Article Class shown above.

Article-Screen1.gif


Options Screen

Finally, the Options Screen allows the user to change the application settings. In terms of settings, so far I can only think of the URL our application will connect to in order to talk to its server counterpart and the number of references to recently viewed articles to keep cached on the device.

Options-Screen1.gif

What’s next

In the next article of this series, I will add the networking code as well as the code to save a retrieve the application settings. After this, I will move to the server side and take care of the pieces that will handle the communications with the device.

History

End-to-End Real World BlackBerry Application, Part 1

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

About the Author

MiamiCoder


I run a small development team for an international Law Firm.
Occupation: Team Leader
Location: United States United States

Other popular Mobile Development articles:

Article Top
Sign Up to vote for this article
You must Sign In to use this message board.
FAQ FAQ Noise ToleranceSearch Search Messages 
 Layout  Per page   
  (Refresh) 
Subject  Author Date 
-- There are no messages in this forum --

General General    News News    Question Question    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

PermaLink | Privacy | Terms of Use
Last Updated: 15 Jul 2008
Editor: Chris Maunder
Copyright 2008 by MiamiCoder
Everything else Copyright © CodeProject, 1999-2008
Java | Advertise on the Code Project