Monday, August 29, 2011

History of Android


The BlackBerry and iPhone, which have appealing and high-volume mobile platforms, are addressing opposite ends of a spectrum. The BlackBerry is rock-solid for the enterprise business user. For a consumer device, it's hard to compete with the iPhone for ease of use and the "cool factor." Android, a young and yet-unproven platform, has the potential to play at both ends of the mobile-phone spectrum and perhaps even bridge the gulf between work and play.
Today, many network-based or network-capable appliances run a flavor of the Linux kernel. It's a solid platform: cost-effective to deploy and support and readily accepted as a good design approach for deployment. The UI for such devices is often HTML-based and viewable with a PC or Mac browser. But not every appliance needs to be controlled by a general computing device. Consider a conventional appliance, such as a stove, microwave or bread maker. What if your household appliances were controlled by Android and boasted a color touch screen? With an Android UI on the stove-top, the author might even be able to cook something.

With the ever increasing use of mobile devices,  especially in developing countries like China and India,  we envision a new generation of applications that will change the ways that we work and live



Motivation

The use of mobile devices has penetrated almost every corner of our world. Many citizens of developing countries like China and India may have never used, let alone owned a personal computer, however now they are using mobile phones in their daily life to conduct businesses and communicate with their co-workers and family members. We envision the unique characteristics of mobile computing (e.g., location-based services) driving a new generation of applications that will change the ways that we work and live today.

One broad class of mobile applications is those that facilitate collaboration, and we imagine that such applications will have a large impact on the developing world. For example, in the developing world mobile collaboration technologies might help knowledge sharing among farmers, sales coordination among small commodity vendors, collaborative learning among village youth, and family-based health care monitoring for the elderly. As most users are not IT experts and they vary in many respects, such as language and technology literacy, one of the challenges is to design and develop consumable collaboration services that can be easily leveraged by the masses (e.g., illiterate users, farmers, and migrant workers alike). If we believe that voice communication and text messaging are the two most used mobile collaboration services today, one interesting question is what would be the next mass-consumable “killer” mobile collaboration service(s) and what factors (e.g., mobile technologies and national culture) would influence the development of such applications/services.

In addition to aiding collaboration between people who already know that they want to collaborate, another interesting area would be to leverage mobile devices to facilitate opportunistic collaboration, which is to help people identify collaboration opportunities unknown in advance. In many situations, people may not have sufficient knowledge about others whom they would like to connect and collaborate with. For example, an orange farmer may want to know about the side effect of applying a pest control substance to her orange grove; or a migrant worker may want to find a new employer to suit his preferred working schedule. However, they may not know where or whom they could get information from, especially when the information provided by a generic service is inadequate. Although researchers in the area of social recommender systems have started to tackle this problem, none of the existing efforts has taken into account the characteristics of mobile devices that would most likely used by people in such situations. For example, it would be interesting to explore whether one’s location information provided by mobile devices could facilitate opportunistic collaboration, and determine which other information provided by mobile devices could help but without sacrificing one’s privacy.

Not only do citizens of the developing world use mobile phones to connect with their fellow citizens, but they may also use mobile devices to communicate with people in the rest of the world. For example, a Chinese businessman in the fashion business may negotiate a contract with a U.S. retailer via mobile phone; and an African farmer may talk to a Chinese farming equipment supplier to arrange a shipment. However, cultural differences, including communication styles and language barriers, may prevent an effective collaboration between them. It would be interesting to examine the barriers systematically and explore innovative way to facilitate such cross-cultural collaboration via mobile devices.




Thinking back, it's hard to believe that with so many Android phones on the market today, that the first version of the Android OS was released only 3 years ago, but the full story starts a few years earlier.

It all began in October 2003 when Andy Rubin, Rich Miner, Nick Sears and Chris White founded Android Inc. in Palo Alto, California. Rubin was quoted by saying the purpose of Android was to allow "smarter mobile devices that are more aware of its owner's location and preferences", though at that time not much else was known about what type of phone software it would turn out to be.

Two years later, Android Inc. was acquired by Google in 2005 (though the amount has never been disclosed) and became a wholly owned subsidiary, but key employees were kept during the acquisition. In the two years that followed, the first Android SDK Beta was released to developers and phone manufactures. This was based on the Linux kernel to allow a flexible and upgradeable system. During this time, Google also helped form the Open Handset Alliance, along with a dozen other software and hardware companies, with the purpose to develop open standards for mobile phones.

Then in September 2008, the HTC Dream G1 was released by T-Mobile as the first device to run on theAndroid 1.0 operating system, which brought us the Android Market, full HTML web browser, GMail and E-Mail connectivity, as well as Google Contacts, Calendar, Maps, Sync, Search, and Media Player. The HTC Dream G1 featured a 3.2" display with 480x320 resolution, sliding QWERTY keyboard, 528MHz processor, 192MB of RAM, and a 3.2MP autofocus camera. 

Google's Android OS: Past, Present, and Future
In February 2009, the HTC Dream G1 was updated to Android 1.1, which added more details in Maps, a longer screen timeout in the dialer, and the ability to save message attachments.

By mid year, there was Android 1.5 Cupcake that added the all important desktop Widgets, on-screen keyboard, faster camera response with video recording, browser copy & paste, and being able to upload videos directly to YouTube. In September 2009, Android 1.6 Donut was released, though there was still only a handful of Android models on the market. Not only did it bring many bug fixes, but also expanded the Voice & Text Search capabilities to include bookmarks & history, contacts, the web, a new Text-to-Speech, support for WVGA displays, and also CDMA/EVDO cellular network support.

When Android 2.0 Eclair hit later in 2009, that's when things started to heat up. It was a more advanced and refined operating system, with updates to almost every aspect of the user interface, including multiple E-Mail accounts, Exchange support, new Browser interface, and Bluetooth 2.1 support. Not only that, but it is also when the originalMotorola DROID came to the market from Verizon Wireless. The device featured a 3.7" display with 480x854 resolution, EVDO Rev A for data, sliding QWERTY keyboard, 600MHz processor, 5MP autofocus camera, Wi-Fi and Bluetooth. This is also when we started to see many more Android devices being manufactured and sold world-wide. 

The next major release was Android 2.2 Froyo in the first half of 2010. This brought new internal optimizations to improve the overall speed, memory, and performance of the operating system. This, along with a new V8 JavaScript allowed the browser to work faster. We also saw an improved Application Launcher, more Widgets, USB tethering, Voice Dialing over Bluetooth, and Adobe Flash support in the Web Browser.

Later that year, Android 2.3 Gingerbread was announced, bring an updated user interface, support for larger and higher-resolution screens, improved power management, redesigned on-screen keyboard, enhanced copy/paste, support for Near Field Communications (NFC), audio effects in the music player, updated download manager, and support for more hardware sensors (gyroscope, barometer). It was then followed by service-updates to Android 2.3.3, 2.3.4 (voice/video chat in Google Talk), and 2.3.5 (for the Nexus S 4G).

Google has also spread its wings into the Tablet market as well. Even though there have been Tablets running Android 2.x since 2010, such as the Samsung Galaxy Tab, the newAndroid 3.0 Honeycomb operating system released in early 2011 is designed specifically for Tablets. The resigned holographic user interface still has an "Android feel" to it, and features a System Bar for accessing notifications, Action Bar, and Multitasking icon for bringing up a thumbnail view of open apps. There are also new desktop Widgets that were introduced in Honeycomb.

Android 2.3.x Gingerbread is still the latest iteration that is in currently available for Android smartphones today (mid-2011). Though the next version has already been announced: Android Ice Cream Sandwich, which is expected to combine elements of Gingerbread and Honeycomb together. Due for release later this year, little is know about it, but it will no longer require phones to have function buttons below the screen, as they will be on the bottom of the screen as icons (similar to how it is done in Honeycomb).

As of August 2011, Canalys research claims that 51.9 million Android devices shipped just in second quarter of this year (five times that of Q2 2010), which now accounts for 48% of all smartphones shipped world-wide. In the U.S. alone, Nielsen Ratings research found that 39% of smartphones were Android, followed by Apple's iOS at 28% and RIM's BlackBerry OS at 20%.

Monday, August 22, 2011

Debugging an Android Application


Before starting that how to debug an android application, it is necessary to know that what is “Debugging”?
Debugging is a methodical process of finding and reducing the number of bugs and defects in a computer program”

Advantage of Debugging:
When you start to make any application in android or in any programming language you will face some bugs, for solving them you need a good understanding of debugging your application.
There are following ways to debug an application in android:
1.) Logcat
Android provides a general-purpose logging package that you can take advantage of to log informational or error messages from your running application. Perhaps of more importance, Android uses this facility extensively to tell you what is going on as it starts up, initiates your application, and tries to run it
2.) Eclipse Debugger
Eclipse provides a source-level debugger that the Android SDK connects with the running Dalvik bytecode, so you have all the debug capability you’d normally expect from a Java program running under Eclipse.
3.) Android Debug Bridge (adb)
This provides a command-line debugging interface to a running Android phone or emulator.
4.) DDMS
Android also provides a special window-oriented debugging environment custom tailored for Android and the Dalvik VM. You can find more about DDMS in our next article “What is DDMS and how it works”

5.) Traceview

An Android-specific utility that tracks all the method calls your application executed and the time spent in each method.
In this article, we will discuss the topic that how to use Logcat and Eclipse Debugger.
1.) Logcat:
First we will understand Logcat; this is most easy way to get error messages from your running application.
To open the Logcat window: go to
Window > Show view > Other, Android > Logcat.
You should be able to see Logcat at the bottom of your screen just like this:
As you can see above, Logcat has different levels of logging.
V stands for Verbose (lowest priority)
D stands for Debug
I stand for Info
W stands for Warning
E stands for Error
How to use??
To use Logcat you have to import android.util.Log in your project.
Then you can call the static class Log.
Here is a sample code snippet:
package com.app.SampleProj;
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
public class MyActivity extends Activity {
    private static final String TAG = "MyActivity";
        /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        Log.i(TAG,"On Create");
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
    }
    @Override
    protected void onDestroy() {
    // TODO Auto-generated method stub
    super.onDestroy();
    Log.i(TAG,"On Destroy");
    }
}
Here is the Logcat:
This is How Logcat Works…!!
You can also filter the Log for making it more clean:
Click in the “+” sign of your Logcat window at the right side of screen, and add new Filter with tag name:
You will see a new Tab which will contain only specific Tags…
This is all about the Logcat, now we come to our next topic Eclipse Debugger.
2.) Eclipse Debugger:
Eclipse provides a built-in “Debugger”, in which you can set “breakpoints” where the program will pause, and allow you to step through the program line by line and inspect the values of variables, amongst other features.
To open the Debugger: go to
Window->Open Perspective->-Debug
You will get a debug Perspective like this:
Now you need to set breakpoint to use debugger. You can set breakpoint by placing your cursor on the marker bar (along the left edge of the editor area) on the line with the suspected code. Double-click to set the breakpoint or right click and click Toggle Breakpoint:
Now debug the application by right click on the selected project and click on the debug as ->android application
Or
By click on the bug button in the tool bar:
The following figure shows the execution break at the first line in the onCreate() method of the activity. You can Step Into (), Step Over (), Step Return (), etc.
Step Into () or F5 key: The next expression on the currently-selected line to be executed is invoked, and execution suspends at the next executable line in the method that is invoked.
Step Over () or F6 key: The currently-selected line is executed and suspends on the next executable line.
Step Return () orF7 key: Execution resumes until the next return statement in the current method is executed, and execution suspends on the next executable line.
This is all about debugging .Hope this article will help you!!