Android Using Intent application

Android Using Intent application

Seemingly ordinary most strange, as hard as it is easy. Northern Song Dynasty. Wang Anshi
Actually, the most seemingly ordinary things extraordinary, simply can not do a good job; success seem very easy, and the success of the process was fraught with hardships.
For we believe that a very common thing, dismissive, would never grow in, down to earth, just from the success and step forward; success does not like to see so easy to find a shortcut is not desirable, we often than others pay more hard work and effort.
Today we are speaking about the principles and applications of the Android Intent.
Earlier we summarize a few important components of Android, I believe we have been for these components have a clear understanding, we look at a few common operations:
Start a Activity: Context.startActivity (Intent intent);
Start a Service: Context.startService (Intent service);
Binding a Service: Context.bindService (Intent service, ServiceConnection conn, int flags);
Send a Broadcast: Context.sendBroadcast (Intent intent);
We found that in these operations, there is an Intent to participate, looks like a very important component, so in the end Intent What is it?
In simple terms, Intent is for data transfer between the various components of the system's data load. When we need to make a call to action, we can tell by Intent Android system to complete this process, Intent is to call an operation notification.
Intent has several important attributes, here we will be introduced one by one:
1.action, actions to be executed
For the following statement of Activity:



TargetActivity stated in its <intent-filter> in the <action>, ie, the target action, if we need to make a jump action, you need to specify the target in the Intent of the action, as follows:



When we specify the appropriate action for the Intent, then call startActivity method, the system will jump to the corresponding Activity according to action.
In addition to the action custom, Intent also contains a number of default action, just to name a few:



Every action has its specific purpose, the following will use to them.
Additional information 2.data and extras, that is to be operated to perform data movement and delivery to destination
Here's give an example to interact with the browser:


The above two methods are the start the browser and open the specified web page, keyword search, corresponding to the action is Intent.ACTION_VIEW and Intent.ACTION_WEB_SEARCH, the former need to specify the page address, which is required to specify the key information for critical word search, the browser will follow the default search engine set up their own search.
We note that when you open the page, specify a data attribute of Intent, which is actually designated to operate the data is in the form of a URI, we can convert a specified string prefix to a specific URI types, such as: " http: "or" https: "represents the network address type," tel: "indicates the phone number type," mailto: "indicates the type of e-mail addresses, and so on. For example, we want to call a given number, you can do this:



So how do we know whether or not to accept such a target prefix it? This requires a look at the matching rules target <data /> element of the.
Target <data /> tag contains the following sub-elements, they define the url matching rules:
android: scheme  matches the url prefix, in addition to the "http", "https", "tel" ..., we can define your own prefix
android: host  url match the hostname portion, such as "google.com", if defined as "*" indicates that any host name
android: port  to match the port url
android: path  matches the url path
We change what TargetActivity Footnotes:



If you specify only action at this time is not enough, we need to set the data value, as follows:



At this time, url and TargetActivity each part of all configuration information is consistent jumps succeed, otherwise it is rejected by the system.
We android: path = "/ target" is amended as android: pathPrefix = "/ target", and to meet the above requirements.
And during the search, we use a putExtra method, the keyword is placed as a parameter Intent, we become extras (additional information), there involves a Bundle object.
Bundle and Intent has a close relationship, it is mainly responsible for the Intent to save additional parameter information, which implements the android.os.Paracelable interface internally maintains a Map property type, with key pairs used to store additional parameters. When placing additional information in our use of putExtra Intent, the method checks the default Bundle examples is not empty, if empty, then create a new Bundle instance, and then place the specific parameter information to Bundle instance. We can also create your own Bundle object, you can then specify the Bundle of Intent, as follows:



It should be noted that, after using the method set putExtras Bundle object, not a reference to the operating system, but the copy operation, and then change the data so bundle instance after you have finished setting will not affect the interior of Intent additional information. How do we get the additional information provided in the Intent of it? Corresponding is, we need to get to the Bundle instance of Intent, and then removed from the key information corresponding to:



Of course, we can also use the Intent of getIntExtra and getStringExtra method to obtain, the data sources are in the Bundle Intent instance of an object type.
Earlier we relate to the three attributes of Intent: action, data and extras. In addition, Intent also includes the following properties:
3.category, to implementation of the objectives of the action or behavior traits have classified
For example: there are usually configured in our application main interface Activity:



Activity on behalf of the target task is the application resides in the initial Activity and the list appears in the application launcher in the system.
Several common category is as follows:
Intent.CATEGORY_DEFAULT (android.intent.category.DEFAULT) default category
Intent.CATEGORY_PREFERENCE (android.intent.category.PREFERENCE) indicates that the target Activity is a preference interface;
Intent.CATEGORY_BROWSABLE (android.intent.category.BROWSABLE) specified after this category, click on the image on the page or link, the system will consider the inclusion of this objective Activity optional list for the user to choose to open a picture or a link.
When setting the category of Intent, you should use addCategory (String category) method to add categories of information specified in the Intent to match the declared goal of Activity in this category.
4.type: To perform a MIME data type of the target actions can handle Activity
For example: a picture of the target can be handled include such mimeType Activity in its statement:


When using Intent match, we can use setType (String type) or setDataAndType (Uri data, String type) to set mimeType.
5.component, package or class name of the target component
When using the component matching, generally use the following forms:




Among them, the first two are used to match the target in the same package, and the third is used to match the objectives of the other package. It should be noted that, if we specify component properties in the Intent, the system will no longer be on the action, data / type, category match.

Android launchMode

Android launchMode

Encircle the wood, was born Haomo; nine of the units, from the tired soil; a thousand miles begins with one step. "I"
Today in the community to see a friend asked, "how to become a top architect within six months," the netizen Road "turn off the lights to sleep, not six months ...", indeed, a dream has come faster. As a programmer, set ambitious goals are admirable, but not just to dream, to practice step by step down. Into a major event, we must start from the little things; everything suddenly starting to micro, quantitative cause a qualitative change.
We talk about today is four launchMode Activity of.
Activity launchMode play in multiple jumps during an important role, it can decide whether to create a new Activity instance, whether to reuse existing Activity instance, whether other public Activity instances where a task. Here's a brief introduction to the concept of task, task stack structure of an object having a task can manage multiple Activity, launch an application, it creates a corresponding task.
Activity There are four launchMode:
1.standard
2.singleTop
3.singleTask
4.singleInstance
We can configure AndroidManifest.xml <activity> the android: launchMode property to more than one of the four can be.
Here we introduced one by one with an example of these four lanchMode:
1.standard
standard mode is the default start-up mode, not the <activity> Configuration android: launchMode property can, of course, you can also specify a value standard.
We will be an Activity, named FirstActivity, to demonstrate what the standard startup mode. FirstActivity code is as follows:




We FirstActivity TextView interface for displaying the current sequence number Activity instance, Button used to jump to the next FirstActivity interface.
Then we click on the button several times in a row, there will be the following phenomenon:



We noted instances of FirstActivity, but the serial numbers are different, and we need to continuously press the Back button twice to return to the first FristActivity. Principle standard mode as shown below:



As shown, the system will generate a jump every time a new instance of the task FirstActivity, and put on top of the stack structure, and when we press the Back button to see the original FirstActivity instance.
This is the standard start-up mode, with or without pre-existing instance, generates a new instance.

2.singleTop
We android specified property on the basis of the above for the <activity>: launchMode = "singleTop", the system will start mode processing in accordance with singleTop jump behavior. We repeat the above several actions, there will be the following phenomenon:



We see the results vary with the standard three sequence numbers are the same, are used to say the same FirstActivity instance; if you press the back button, the program quits immediately, indicating the current stack structure is only one instance of Activity ʱ?? Principle singleTop mode as shown below:



As shown above, when the system will first look for a jump in the stack structure to see if there is an instance of positive FirstActivity top of the stack, if there is no longer generate new, but directly. Maybe my friends have doubts, I only see the stack is only one Activity, if it is more Activity how to do, how, if not in the stack? We followed through an example to confirm what everyone's questions.
We then create a new Activity named SecondActivity, as follows:




Then the code before FirstActivity Jump to:



Yes, FirstActivity will jump to SecondActivity, SecondActivity will jump to FirstActivity. Demo results are as follows:



We see two FirstActivity serial number is different, proved to jump from SecondActivity FirstActivity generate a new FirstActivity instance. Schematic is as follows:



We see that when the jump from SecondActivity to FirstActivity, the system finds there FirstActivity instance, but not at the top of the stack, then re-generate an instance.
This is singleTop start mode, if there Activity instances corresponding right in the top of the stack, then re-use, no longer generate new instance.

3.singleTask
In the above basis, we modify FirstActivity attributes android: launchMode = "singleTask". The results demonstrate the following:



We note that in the above process, FirstActivity serial number is unchanged, SecondActivity serial number is not the only, explanation jump from SecondActivity to FirstActivity, does not generate a new instance, but to jump from FirstActivity SecondActivity When generating a new instance. Schematic singleTask mode as shown below:



In the bottom half of the figure is to jump to the results of the stack structure SecondActivity FirstActivity after changes, we note that, SecondActivity disappeared, yes, the jump in this process, the system found FirstActivity instance exists, so longer generates new examples, but the Activity instance FirstActivity all over the stack, the stack becomes FirstActivity object to display to the foreground. Maybe my friends have questions, if you will SecondActivity also set to singleTask mode, SecondActivity instance is not uniquely it? In our example this is not possible, because every time you jump from SecondActivity to FirstActivity, SecondActivity instance when forced out of the stack, jump to the next and so on FirstActivity SecondActivity, can not find the presence of SecondActivity instance, then you must generate the new instance. But if we have ThirdActivity, let SecondActivity and ThirdActivity another jump, then SecondActivity instance can guarantee unique.
This is singleTask mode, if there are corresponding Activity instance, makes this Activity Other Activity Examples Example above all out of the stack, so this Activity instance a stack object display to the foreground.

4.singleInstance
This startup mode is rather special, because it would enable a new stack structure, Acitvity placed in the new stack structure, and ensure no other instance enters Activity.
We modified FirstActivity of launchMode = "standard", SecondActivity of launchMode = "singleInstance", as it relates to multiple stack structure, we need to show id current stack structure in each Activity, so we add the following code for each Activity:



Then we'll show you the process:


Activity instances we found that the two were placed in a different stack structure, on singleInstance principle is as follows:



We see the jump from FirstActivity to SecondActivity, re-enable a new stack frame, to place SecondActivity instance, and then press the Back key, to return to the original stack structure; the figure jumped again in the bottom half of SecondActivity Go FirstActivity, this time the system will generate an original stack structure FirstActivity instance, and then rolled back twice, attention, and did not quit, but returned to the SecondActivity, why? Because the jump from SecondActivity to FirstActivity time, our starting point into a stack structure where SecondActivity instance, this way, we need to "return" to the stack structure.
If we modify the launchMode FirstActivity value singleTop, singleTask, singleInstance any one, the process will be as shown:





singleInstance startup mode is probably the most complex a model, in order to help you understand, I give an example, if we have a share applications, which is the entrance ShareActivity Activity, Activity also calls for other applications, we put the Activity of Start mode is set to singleInstance, then call in other applications. We edit ShareActivity configurations:



So then we start the Activity in other applications:



When we open ShareActivity then press the Back button to return to the original interface when, ShareActivity exist as a separate entity, if the time we open share applications, without having to create a new instance of ShareActivity to see the results, because the system will automatically find, It exists directly. You can print in ShareActivity about it taskId, to see the effect. On this process, the principle is as follows:



Android using HTTP service

Android using HTTP service

In Android, in addition to using java.net package under the API to access HTTP services, we also can change a way to complete the work. Android SDK comes with Apache's HttpClient API. Apache HttpClient is a complete HTTP client, which provides full support for the HTTP protocol, you can use the HTTP GET and POST access. Here we combine instance, tell us about the use of the HttpClient.
Http we create a project, the project structure is shown:



In this project, we do not need any of Activity, all operations are done in the unit test class HttpTest.java in.
Because the use of the unit test, so here to tell us about how to configure the Android unit testing. All configuration information is done in AndroidManifest.xml:



Then, our unit test class needs to inherit android.test.AndroidTestCase class, which itself is inherited junit.framework.TestCase, and provides getContext () method is used to get Android context, this design is very useful because many Android Context API are required to complete.
Now let's look at our test case, HttpTest.java code is as follows:




Because this file contains three test cases, one by one so I will explain.
First, note that we use when positioning server address to the IP, because there can not be localhost, the server is running on the windows, and this unit test run in the Android platform, it means that if you use localhost to access the interior Android services may not be accessed, it must use IP to location services.
We first analyze testGet test cases. We use a HttpGet, request parameters directly attached to the back URL, then perform a GET request by the HttpClient, if the response is successful, made within the response stream as input and convert it to a string, and finally determine whether the GET_SUCCESS.
testGet the corresponding server-side testing Servlet code is as follows:



Then say testPost test cases. We use a HttpPost, URL back and did not come with the parameter information, parameter information is packaged into a form set by the NameValuePair type composition, and then process the call after UrlEncodedFormEntity HttpPost of setEntity method parameter settings, and finally executed by HttpClient.
testPost test corresponding server-side code is as follows:


The above two are the basic GET requests and POST requests, arguments are text data types, to meet the needs of the ordinary, but in some situations, for example, when we use to upload files, you can not use the basic GET and POST requests request, and we want to use a multi-part POST request. Here's how to use multi-part POST operations upload a file to the server.
Since HttpClient version shipped with Android does not support multi-part POST request, so we need to use a HttpMime open source project, this component is to deal specifically with the MIME type of related operations. Because HttpMime HttpComponents is included in the project, so we need to go to the official website to download apache HttpComponents, then put them into the project to go HttpMime.jar package, as shown:



Then, we observe testUpload test, InputStreamBody processing document flow parameters we use HttpMime provided with StringBody deal with ordinary text parameters, and finally all the type parameters are added to a MultipartEntity instance, and this is set to the POST request multipartEntity parameter entities, and then perform the POST request. Servlet server code is as follows:




The service uses apache open source project FileUpload processing, so we need to jar package commons-fileupload and commons-io these two projects, the development of the service side are not familiar with friends can go online to look at the relevant information.
After the above described three different situations, we need to consider a problem in practice, we can not always create HttpClient, but should only create an HttpClient for the entire application, and use it for all HTTP traffic. In addition, it should be noted that multi-threading problems that may occur when passing through a HttpClient also issued multiple requests. For these two issues, we need to improve the look of our project:
1. Expand the system default Application, and applied in the project.
2. Use ThreadSafeClientManager HttpClient library provides to create and manage HttpClient.
Project structure improved as shown:


MyApplication which extends the system's Application, the following code:




We rewrite the onCreate () method, when the system starts to create an HttpClient; rewrite the onLowMemory () and onTerminate () method to close the connection at the end of insufficient memory, and application, free up resources. It should be noted that, when instantiated DefaultHttpClient, passing an instance from one ClientConnectionManager ThreadSafeClientConnManager created, responsible for managing the HttpClient HTTP connection.
Then, I want to let this enhanced version of "Application" effect, you need to do the following configuration in AndroidManifest.xml:


If we are not configured, the system will default to android.app.Application, we added the configuration, the system will use our com.scott.http.MyApplication, then you can call in the context of the getApplication () to get the MyApplication instances.
With the above configuration, we can apply in the event of, HttpActivity.java code is as follows:





Click the "execute" button, the execution results are as follows: