Working with Layout Managers - User Interface in BlackBerry

Introduction

BlackBerry is a line of mobile e-mail and smartphone devices developed and designed by Research In Motion (RIM) since 1999 and the two BlackBerry development environments produced by RIM. The BlackBerry Java Development Environment (JDE), and the BlackBerry JDE Plug-in for Eclipse, you already learned in my previous article "Start developing BlackBerry Application". Now we start working on BlackBerry User Interface.

When we talk about BlackBerry User Interface the very first thing which you have to know that is Layout Managers.

What is Layout Manager

RIM's layout managers are akin to Swing layout managers, and allow you to arrange lots of fields on the screen, it is responsible for determining where a UI element will be positioned on the display. The BlackBerry software library comes with a set of pre-made layout managers, and the MainScreen class uses the VerticalFieldManager as its default layout manager.

blackberry screen

The Screen Class has "layout managers", but we called it as Field Managers. We have several Screen Classes:

Hierarchy of Screen Class

java.lang.Object

--net.rim.device.api.ui.Field

   --net.rim.device.api.ui.Manager

      --net.rim.device.api.ui.Screen

This Screen is the base class for all screens.

The BlackBerry User interface API follows a Fields/Layout Managers/Screens models: Fields are contained within layout managers, which arrange and draw them in spacific positions. We have some built in layout managers:

Built in Managers

We have four built in layout managers:

  1. VerticalFieldManager : This layout manager simply lays out the fields you add to it, from top/bottom.
     
  2. HorizontalFieldManager : This layout manager simply lays out the fields you add to it, from left to right, on one row.
     
  3. FlowFieldManager : This layout manager lays out fields in a horizontal-then-vertical flow.
     
  4. DialogFieldManager : This layout manager used for Dialogs and status screens. It handles an icon, a message, and an area to hold a list of user specified fields.

Now Lets Code:

Step 1 : Open BlackBerry Java Plug-in/Eclipse.

eclipse for blackberry

Step 2 : Choose a Project from File/New.

new project in eclipse

Step 3 : Choose BlackBerry Project wizard and click on Next.

blackberry project

Step 4 : Now give a name to your project like I gave "Layouts" and click on Finish.

blackberry project name

Step 5 : Go to the Project Explorer and You will see two auto-generated class's "MyApp.java and MyScreen.java" under Layouts project folder src/mypackage.

my package in blackberry application

MyApp.java class is contains the main(String[] args) method and so is where we define our application. If you want any kind of user interaction, then one of your classes must extend this class because it provides all the default behavior for such an app. Within the main(String[] args) method, you must define an instance of the class like for MyScreen.java.

Code Behind of MyApp.java Class

This class is auto-generated, you do not need to change any code in this class let it be remain same:

package mypackage;
 
import net.rim.device.api.ui.UiApplication;
 
/**
 * This class extends the UiApplication class, providing a
 * graphical user interface.
 */
public class MyApp extends UiApplication
{
   
/**
     * Entry point for application
     *
@param args Command line arguments (not used)
     */

   
public static void main(String[] args)
    {
       
// Create a new instance of the application and make the currently
        // running thread the application's event dispatch thread.
        MyApp theApp = new MyApp();      
        theApp.enterEventDispatcher();
    }
 
    /**
     * Creates a new MyApp object
     */
    public MyApp()
    {       
       
// Push a screen onto the UI stack for rendering.
        pushScreen(new MyScreen());
    }   
}

Step 6 : Open the MyScreen.java class and code inside this class for different layout managers:

First you have to import this three classes:

import net.rim.device.api.ui.*;
import net.rim.device.api.ui.component.*;
import net.rim.device.api.ui.container.*;

Now code as per your required FieldManager.

Code for VerticalFieldManager

package mypackage;
 
import net.rim.device.api.ui.*;
import net.rim.device.api.ui.component.*;
import net.rim.device.api.ui.container.*;
 
public final class MyScreen extends MainScreen
{
   
public MyScreen()
    {       
     
// create a manager and allow scrolling when lots of fields are added
        VerticalFieldManager vrfm = new VerticalFieldManager(Manager.VERTICAL_SCROLL);
       
        LabelField label1 =
new LabelField("VerticalFieldManager"){
           
public void paint(Graphics graphics) {               
                graphics.setBackgroundColor(Color.
LIGHTGREEN);
                graphics.clear();
               
super.paint(graphics); 
            }
        };       
       
        LabelField label2 =
new LabelField("Default horizontal left alignment"){
           
public void paint(Graphics graphics) {               
                graphics.setBackgroundColor(Color.
LIGHTPINK);
                graphics.clear();
               
super.paint(graphics); 
            }
        };
       
        LabelField label3 =
new LabelField("Using all width and long label",
                               LabelField.
ELLIPSIS | LabelField.USE_ALL_WIDTH){
           
public void paint(Graphics graphics) {               
                graphics.setBackgroundColor(Color.
LIGHTSKYBLUE);
                graphics.clear();
               
super.paint(graphics); 
            }
        };
       
        LabelField label4 =
new LabelField("Horizontally centered alignment",Field.FIELD_HCENTER){
           
public void paint(Graphics graphics) {               
                graphics.setBackgroundColor(Color.
LIGHTGOLDENRODYELLOW);
                graphics.clear();
               
super.paint(graphics); 
            }
        };             

        vrfm.add(label1);
        vrfm.add(label2);
        vrfm.add(label3);
        vrfm.add(label4);
        add(vrfm);
     }
}

In the above code by using setBackgroundColor() method for the specific "LabelFields" and overriding the "LabelFields" paint routines we get the "LabelFields" with different color's.

In the constructor of VFMScreen, a vertical field manager is created and a style parameter is passed to it, telling it to enable vertical scrolling if lots of fields are added.

Note : Don't forget to add vertical field manager to the screen at last in the program like I do "add(vrfm);".

Screenshot

VerticalFieldManager in blackberry

Code for HorizontalFieldManager

package mypackage;
 
import net.rim.device.api.ui.*;
import net.rim.device.api.ui.component.*;
import net.rim.device.api.ui.container.*;
 
public final class MyScreen extends MainScreen
{
   
public MyScreen()
    {   
     
// create the layout manager, and enable scrolling...
        HorizontalFieldManager hrfm = new HorizontalFieldManager(Manager.HORIZONTAL_SCROLL);       
       
        LabelField label1 =
new LabelField("Default Value.."){
           
public void paint(Graphics graphics) {               
                graphics.setBackgroundColor(Color.
LIGHTGREEN);
                graphics.clear();
               
super.paint(graphics); 
            }       
        };        

        // if field is not focusable, then scrolling will not work!
       
        LabelField label2 =
new LabelField("HRFM #Focusable for Scrolling#",
                            Field.
FIELD_VCENTER | Field.FOCUSABLE){
           
public void paint(Graphics graphics) {               
                graphics.setBackgroundColor(Color.
LIGHTGREEN);
                graphics.clear();
               
super.paint(graphics); 
            }
        };          
       
        Font myFont = Font.getDefault().derive(Font.
BOLD, 12, Ui.UNITS_pt);
        label1.setFont(myFont);
        label2.setFont(myFont);
                              
        hrfm.add(label1);
        hrfm.add(label2);
        add(hrfm);
     }
}

Note : When you add a lot of Field objects to a VFM, you should remember to make them FOCUSABLE because the VFM allow the scrolling when the fields that are off the visible portion of the screen are set to focusable otherwise it will not allow scrolling to them.

Screenshot

HorizontalFieldManager in blackberry

Scroll horizontally and see the remaining fields

HorizontalFieldManager in blackberry

Code for FlowFieldManager

When we work with FlowFieldManager, vertical scrolling is enabled by default. As you add more fields, they will just be added beside the existing ones.

package mypackage;
 
import net.rim.device.api.ui.*;
import net.rim.device.api.ui.component.*;
import net.rim.device.api.ui.container.*;
 
public final class MyScreen extends MainScreen
{
   
public MyScreen()
    {   
       
// default style is Field.USE_ALL_WIDTH | Manager.VERTICAL_SCROLL
        FlowFieldManager ffm = new FlowFieldManager();
       
       
//new FlowFieldManager(Field.USE_ALL_WIDTH | Manager.VERTICAL_SCROLL | Field.FIELD_VCENTER);
        LabelField label1 = new LabelField("Bottom Aligned", LabelField.FIELD_BOTTOM){
           
public void paint(Graphics graphics) {
                  graphics.setBackgroundColor(Color.
LIGHTGREEN);
                  graphics.clear();
                 
super.paint(graphics);
            }
        };
       
        LabelField label2 =
new LabelField("Top Aligned", LabelField.FIELD_TOP){
           
public void paint(Graphics graphics) {
                  graphics.setBackgroundColor(Color.
LIGHTCORAL);
                  graphics.clear();
                 
super.paint(graphics);
            }
        };
       
        LabelField label3 =
new LabelField("FlowFieldManager Center Aligned", Field.FIELD_VCENTER){
           
public void paint(Graphics graphics) {
                  graphics.setBackgroundColor(Color.
LIGHTGRAY);
                  graphics.clear();
                 
super.paint(graphics);
            }
        };
       
        LabelField label4 =
new LabelField("Default Vertical Aligned"){
           
public void paint(Graphics graphics) {
                  graphics.setBackgroundColor(Color.
LIMEGREEN);
                  graphics.clear();
                 
super.paint(graphics);
            }
        };
       
        Font myFont = Font.getDefault().derive(Font.
BOLD, 9, Ui.UNITS_pt);
        label1.setFont(myFont);
        label2.setFont(myFont);
        label3.setFont(myFont);
        label3.setFont(myFont);
                             
        ffm.add(label1);
        ffm.add(label2);
        ffm.add(label3);
        ffm.add(label4);
        add(ffm);
     }
}

In above code we add a variety of labels to the flow field manager. A variety of different styles are passed to the constructors of these fields themselves that determine how they are laid out.

Screenshot

FlowFieldManager in blackberry

Code for DialogFieldManager

Import these two classes for working with
BitmapField

import net.rim.device.api.system.Bitmap;
import net.rim.device.api.ui.component.BitmapField;

Complete Code

package
mypackage;
 
import net.rim.device.api.ui.*;
import net.rim.device.api.system.Bitmap;
import net.rim.device.api.ui.component.BitmapField;
import net.rim.device.api.ui.component.*;
import net.rim.device.api.ui.container.*;
 
public final class MyScreen extends MainScreen
{
    
public MyScreen()
    {   
         
      DialogFieldManager  dfm =
new DialogFieldManager ();
     
      Bitmap bitmapImage = Bitmap.getBitmapResource(
"Icon.gif");
      dfm.setIcon(
new BitmapField(bitmapImage));
     
      dfm.setMessage(
new RichTextField("Heading of DialogFieldManager"));
             
      dfm.addCustomField(
new LabelField("Bottom Aligned", LabelField.FIELD_BOTTOM));
      dfm.addCustomField(
new LabelField("Top Aligned", LabelField.FIELD_TOP));
       
      Bitmap bitmapImage1 = Bitmap.getBitmapResource(
"Image.gif"); 
      dfm.addCustomField(
new BitmapField(bitmapImage1));       
       
      dfm.addCustomField(
new LabelField("FlowFieldManager Center Aligned", Field.FIELD_VCENTER));
      dfm.addCustomField(
new LabelField("Default Vertical Aligned"));
                    
      add(dfm);

     }
}

In the above you you see first we set an icon (which goes on the top row). Then a formatted label (RichTextField) is set on the top row as well and so on variety of labels are added.

Screenshot

DialogFieldManager in blackberry

Thank You....

Up Next
    Ebook Download
    View all
    Learn
    View all