Serializable & Parcelable class can be used to pass object references from one Activity to the other Activity via Intent/Bundle. Your object must implement either Serializable or Parcelable in order to pass it via Intent.
Serializable is defined in JAVA language as a marker interface, so after implementing Serializable no extra method implementation is needed. It is very easy to use, but the performance is not good since serializing mechanism is decided by Java and it uses refelection.
Parcelable class is provided by Android platform, and its performance is much faster than Serializable (according to this blog, it is more than 10 times faster!!). This is because the serialization method is explicitly written in Parcelable class. It means you need to implement serialization method, following 4 methods/members, which is quite troublesome.
writeToParcel()
Constructor with argument Parcel
Parcelable.Creator<> CREATOR
createFromParcel()
newArray()
describeContents()
Binder and AIDL works with Parcelable.
Using Android studio plugin to Easily implement Parcelable class
1. Open class which you want to implement Parcelable, and Press [ALT+Insert] (cursor position doesn’t matter, plugin always insert automatically generated code at the bottom of class). You can select “Parcelable”.
2. Select fields to be parceled. Usually just press OK.
3. Done! below methods are automatically generated, so easy.
* The tips written here is not officially supported, and I don’t take any responsibility caused by using this Technique. Try it with your own responsibility.
Watch browser contents on TV more easily
When you are browsing on the Internet with PC or Smartphone/Tablet in home, especially when streaming video contents, have you ever wanted to see it on big TV display?
Android TV initially don’t support browser app (It is officially stated that Android TV may not have browser app initially), but you can install browser app on Android TV. For example, there is Web Browser for Android TV on Play Store now. Also, SONY Android TV contains Pre-installed OPERA browser for now.
So you can watch any web contents on TV!! But the problem is,,, even if you have a specific website which you want to watch on TV in mind, navigating to this website on TV is quite troublesome since we usually don’t use keyboard to search contents within TV app (Android TV supports mouse and keyboard, so you can actually connect these devices to use TV like a PC, but TV is used with relaxing mode so few people uses such a way).
So I was thinking when I’m browsing on PC, it is nice if we could cast current URL on PC to Android TV so that we don’t need to type anything on TV side. And yes! we can utilize Android platform to achieve this request:)
* Google cast also achieves this request, but sometimes it doesn’t work in my environment. So I will post different solution here.
Google Chrome to Phone app & Chrome to Phone extension
Google Chrome to Phone is made by Google, achieves to share links between your PC’s chrome and “device”. Of course the “device” is supposed to be a Android phone, but we can install Android phone’s app on Android TV as well by using the technique mentioned at
After installed app and plug-in, you need to set up both of them by logging in with same Google account.
How to use
After set up done, it is very easy to use and it is conveniently automated. We can cast PC side’s website URL to TV side and TV side automatically launch browser app to show this URL.
PC side: Launch Chrome and go to your favorite website that you want to show on TV
PC side: Click top-right icon Basically that’s all! Then,
(This procedure might be necessary) Android TV side: launch browser app
Android TV side: browser app automatically move to the URL specified by PC side. Enjoy watching web contents on big, beautiful TV display 🙂
Conclusion
Now the PC side web page can be sent to TV side by just one click, it enhanced my opportunity to enjoy many kinds of web video contents on TV. I realized some of the HD stream videos are quite nice to watch with TV.
If the PC and TV is in the same room, you can even utilize TV as second (or third) monitor to stream video/music even it is not connected via HDMI cable.
Let me know your idea of life hacking technique of Android TV as well!!
* This post is written in 2015 Oct, the design might change in the future.
Customizing WordPress theme “Graphy” – Optimize blog design for technical blog –
It has been 4 month since I started this blog on June. I was just focusing on showing the main contents for the starting point. But now published posts was increased so that it is possible to show users “Related post” or “Popular post”.
This blog is powered by WordPress, by using free theme “Graphy“. It is really simple and beautiful design, makes us feel “reading” typography. I feel it is especially suitable for writing “novel” type posts so that user can concentrate on reading text. However, I prefer to change some styles to optimize it for my blog category “technology posting”. Here is a memo for these changing points and their reasons (Of course, these are just my personal opinion & preference).
Child theme
What is the best way to code your modification of original theme? If original theme codes are modified, these modification will disappear when we update this theme. To cope with these problems, WordPress supports a nice functionality called Child themes, so that user can implement their own customize in a separated module.
It works very similar to extending parent class in object oriented programming. So that you only need to overwrite the difference from parent theme. Let’s get a example by making graphy’s child theme!
At least you need to make 1 folder and 2 files.
1. Make directory named “graphy-child” at /wp-content/themes/ where all themes are stored. We can implement customized styles and codes in this folder.
2. Make style.css file inside graphy-child, must include following meta information.
Note that child theme’s functions.php does not overwrite parent’s functions.php, instead, it is loaded right before the parent’s functions.php. So we don’t need to copy paste parent’s file, but just need to implement our own additional functions.
Ok, minimum implementation is done. We can now choose “graphy-child” theme from Dashboard → Appearance → Themes.
Now we can proceed to customize the theme just by modifying child theme, especially style.css.
A. Single column? Two column? Three column?
To start considering a layout of the web site, the base layout should be determined. WordPress theme can be categorized either of below.
Single column It does show main contents in the center, while it is not good at showing other sub-contents/links. Suitable for those who want user to concentrate on reading main contents.
Two column It can show main contents in primary row as well as sub-contents in secondary row. Suitable if you want to include internal-links while maintaining simple design.
Three column There are two side bars among center main row. So you can put many sub-contents (profile, archives, related posts, popular posts, recent posts, advertisements, social icon, interlinkage etc…). Suitable for contents portal page, so that you want to show many attractive posts.
The support for these layout depends on the theme. Graphy supports single column and two column layout. Graphy is more focusing on simple design, showing main contents.
I was using single column until today to focus on showing the main contents. But I want to navigate user to other contents as well now, so I have changed layout to two column to show “Related post” and “Popular post”.
WordPress Popular Posts plug in – Showing popular post
“Related post” can be displayed from default customization, but “popular post” is not possible since WordPress don’t save the number of views by default. However, we can show popular posts very easily by installing plug in. Famous plug in is WordPress Popular Posts and WP-PostViews. I adopted WordPress Popular Posts, you can seepopular posts ranking as well as number of views at the right-top corner.
Source code is frequently written in this blog, and it is nice to show one line programming in one line. Therefore, I wanted to keep main contents area wide enough. To prevent the side effect of layout change to two column, I increased the width attribute of main layout.
C. Make texts more packed – change line height
I noticed there is a big spacing beween each line with Graphy’s original design. It emphasizes background white space, this is indeed one factor that contributes to make Graphy beautiful. It is good for reading novels, though it is not suitable for technical contents. When we study something, it is usually difiicult to understand the contents just by reading once. We often need to go back and forth while reading. Therefore, I prefer text contents to be packed so that we can refer previous sentence without scrolling so much. Textbooks, technical books, technical papers are mostly packed, aren’t they?
Modify style.css. You can find at the wordpress Dashboard → Appearance → Editor → Styles (bottom-right) > Stylesheet > style.css
font-size attribute defines the spacing/margin between lines, change it for your preference. I decreased the header’s font size in this blog.
margin-bottom, margin-top attributes are used to dtermine the spacing/margin between each blocks. I decreased the “Asap”, “Verdana”, “Arial”, and “sans-serif” font for this blog.
line-height attribute defines the spacing/margin between lines, change it for your preference. I decreased the values from original.
D. Change style of code attribute
code and pre attributes are important to explain about methods, class, or source code etc. I put color on code HTML tag attribute.
It is a racing game similar to Mario Kart. You can use item to power-up or defeat other cars during the race. Graphics is animation style rather than realistic, so it is well acceptable for whole family (especially child).
It is an action game. The graphics is very smooth 3D. You can use left joy stick for move and right joy stick for punch. You need to remember a little bit of command to play, so it is not simple compared to other games, but there is a Tutorial at the first time of game play and you can understand how to enjoy game.
It is FPS (First Person Shooting) game. The game is subjective view, so you can feel realistic, dynamic world in the game. It feels like it targets simply enjoyable game with story rather than complicated action game. For example, the attack is done by automatically when you set your sights on enemy. It is amazing that we can enjoy these games for free without console games nowadays!
It is a tower defense game, goal to protect your city on the left side from monsters coming from right side. You can use bow and magic to defeat monsters. When I play game was easy and rule was simple, easy to enjoy.
It’s an adventure game, more concretely it is like “playing movie”. It is focusing on story rather than action. You have so huge number of times of chance to choice your action, even for the reply of daily conversation. You can also enjoy a little bit of an action when fighting with living dead. The game contains violence and scary, suitable for adults. As you can see, the graphics is realistic, which is a nice point but at the same time one dis advantage is that the size of the game is big (season one: 1.3 GB, season two 700 MB).
For the season two, you can take over the save data of Season one. the choice made in season one affects the story of season one. You might need to pay for enjoying next episode.
It is platform action game, but you can have various weapons, armors to make hero strong. Each stage is called “Chapter X, dangeon Y” and the game is storynized.
FPS (First Person Shooting) game. It contains typical elements for these shooting games like aiming target, shooting, reloading, hide to wall, change gun, precise aiming mode… You can get strong weapons when you pay money.
It is a racing game, the difference comes from it is focusing on drift experience. If you practice and become good player, you can enjoy drifting the courses all over the world!
It is a simple platform action game, similar to super mario. Hero goes the stage and help caught people. The game is designed with old style “dot” picture, which makes the world cuter.
Not long time past since “Android TV” is released, but some interesting games are already released for this Android TV market. You can enjoy all following game for free. But of course, the app developer is making these game apps for business, there’s a in-app purchase for almost all the games. Usually, you need to pay when you want to resume at gameover timing or you want to get extra power up items in the game.
* The number of installs are based on the time of writing, 2015/10/11.
It is very simple, “endless arcade hopper” game. Yes, it is endless. You can try and continue as far as you can go. There are many characters, e.g. pack man, chicken, etc. After you get coin in the game or purchasing, you can play the game with these characters.
The exciting race game! As you can see, the graphics is so nice and music is also very dynamic and exciting when you play with the TV! I feel it is really good to play with big TV display, rather than just a hand phone.
There are many racing games on Android TV Google Play Store, but many of them requires game pad to play. The game made by Gameloft is very well-made in detail. It can be played without game pads or you can play with remote controllers as well. When I play with SONY BRAVIA, it detected remote controller, and shows the Tutorial specific for this remote controller.
Simple runner action game as well. But it is more simple that only “center” key is enough for playing game. Nice thing is you can enjoy a game. Even you die in the game, you can continue without pay extra money.
The card puzzle game, as you can easily imagine from image. At first I was thinking of a game Solitaire, but it was different. However, the rule is similar so you can play without any explanation if you know the rule of Solitare (and FreeCell). This game is not so difficult, I took around 30 min to win one game. See Wikipedia page for the details.
This is a driving game, but not racing game. It was introduced as “A strategic driving game” in the Google Play Store. So why “strategic”? This game is unique that you will drive tens of cars in the same map, and at the time when you drive new cars, old cars which you have driven interferes the way. You struggle because of your driving… The map made like 1970’s town together with the matching background jazz music makes this game atmosphere cool!
You can play the game only left and right key, thus without game pad. But you feel comfortable with gamepad, since X key can be used to rewind current stage.
I think no need to explain what PAC-MAN is. This is derivative version of PAC-MAN, that aims to go up upper and upper of this endless stage, which is similar to Crossy Road.
The game is free without power up, and you can pay as an option to get extra power up.
Shooting game. The number of install looks small, this is just because the game is provided only for Android TV devices, while all other game apps above are provided both Android phone and TV devices.
You can also enjoy multi-player play. For example 1P uses remote controller & 2P uses game pad.
I could notice current game market trend during summarizing this post. Now game is made for cross-platform. Most of the popular game app is not only for Android TV, but it is for PC, Play Station 3 or 4, Wii, Android phone/tablet etc. So, big game software companies are just importing existing game into Android TV platform. Since it was already made for other platform (using a big development cost), the quality of these cross-platform game is usually quite nice.
Importance of beautiful graphics and background music/sound
After experiencing to play Android TV games, I felt Android TV game and Android phone game are different. We can enjoy dynamic, beautiful graphics with big screen. Just a difference of screen size? I would say the difference of screen size provides different user experience!!!
Also, the importance of sound becomes much higher. You might play Android phone games with mute, however, you definitely play Android TV games with (maybe big) sound. Especially for racing games or shooting games, the dynamic sound makes user’s emotion more exciting. Additionally, home theater system provides you much presence for the game.
Simple game is also just fine
As written above, most popular apps are high quality. Graphics is smooth 3D, and sound is also created deeply to express game world’s atmosphere.
This is an opposite comment from above, but there also is a demand to play simple, easy game for just enjoy a slice of time. It is possible to reach more than 1 Million download with simple game apps (like Jelly king, PAC-MAN), 1 Million is quite enough number isn’t it?
What kind of game is not yet on the Android TV market?
There already is action, racing, shooting, simple platform game on Google Play Store, even though the future market growth of Android TV market is not known yet.
As one opinion, I felt Music game is interesting. I found the app “Radiohammer Station” on Google Play Store, but it was not optimized for Android TV device yet. I could not play with game pad key.
Another category is Social game like FarmVille. Especially, it is a interesting topic to consider game for women. For example, housewife is alone in the house on the daytime of weekday, they are important target for TV market to consider.
My first motivation was to use AndroidManagerNative class, even you can find this class in Android open source project, you can’t use it in our app when you build with usual Android SDK.
Yes, some of the classes are hidden in SDK. More specifically, $SDK_PATH/platforms/android-xx/android.jar contains limited APIs for Android app developers.
I put memo how to use these hidden classes/methods in your Android app development from Android studio (which works with build.gradle).
Building Android SDK including all APIs
First step is to prepare library which includes hidden Android APIs. Below link answers how to do this.
copy out out/target/common/obj/JAVA_LIBRARIES/framework_intermediates/classes.jar (better to rename it as something like framework_all.jar)
config your project build path–>libraries –> add this external jars. In Order and Export, move it up and before android.jar
So after fullbuilding AOSP source code, you can get desired jar file at out/target/common/obj/JAVA_LIBRARIES/framework_intermediates/classes.jar I will note it as framework_all.jar in the following.
trouble writing output: Too many method references: 83845; max is 65536.
There is a limitation dx compiler, up to 65536 method references is allowed per one dex file, while framework_all includes more than 65536 methods. I got following error
trouble writing output: Too many method references: 83845; max is 65536.
You may try using --multi-dex option.
References by package:
27 android
147 android.accessibilityservice
598 android.accounts
...
To cooperate this, add multiDexEnabled options to support multidex inside defaultConfig closure,
What has changed from Android Lollipop to Marshmallow from user point of view on Android TV? Below is the noticeable changes when I use Nexus Player with Android Marshmallow (see how to update).
Precise permission control for each App
When we go to [Settings] → [Apps] → Select specific app → [Permissions], we can set to allow/disallow apps to use permissions one by one. It becomes more customizable, (I fell it too complicated though).
Security patch
Other than the Android software version update, it seems there’s a Android security patch update frequently.
So far, the big change I can find from user point of view is only these stuffs. Followings are the minor changes.
Boot up animation
Android M boot up animation is different but similar to the Lollipop, 4 balls are interacting animation will be repeated during the boot up.
Hidden game
Google often put some joke implementation in their product. Android is not the exception, it contains a hidden playing game. Go to [Settings] → [About] → press [Version] many times, then the game starts. It was almost same with Lollipop, but there’s a change in the obstacle, it is Marshmallow! See How to enable developer mode in Android TV for Lollipop game.
I will explain the steps to update software of your Nexus Player to Android M. The steps should be almost similar to other Nexus devices as well.
Flashing factory image to Nexus Player
Step 0. install adb and fastboot command
This method is for developers since it requires Android SDK tools set up such as, “adb” and “fastboot” command. If you haven’t set up these commands, you can set up by Building adb and fastboot command from AOSP source code. If you feel it trouble some to build adb and fastboot command manually in your PC, see also
Download the factory image which you want to flash from Google developer’s page (direct factory image download link here for Nexus Player). “fugu” is the project name for Nexus Player.
After downloading, extract it.
tar -xvzf fugu-mra58k-factory-61ac65bc.tgz
Step 2. Boot Nexus Player in bootloader mode
Boot up Nexus Player as usual, connect PC with adb, then reboot it with bootloader mode by
adb reboot bootloader
Bootloader mode on Nexus Player looks like this,
Step 3. Unlock bootloader
First check your fastboot is detecting device correctly or not by checking
I needed to execute command twice to get device unlocked.
~/workspaces/download/fugu-mra58k$ fastboot oem unlock
...
FAILED (remote: To confirm, send the unlock command one more time)
finished. total time: 0.611s
~/workspaces/download/fugu-mra58k$
~/workspaces/download/fugu-mra58k$ fastboot oem unlock
...
OKAY [ 10.089s]
finished. total time: 10.089s
Step 4. Flash factory image
Finally we can flash factory image by
$ cd fugu-mra58k/
$ ./flash-all.sh
Extracted file contains flash-all.sh script, so we can use it to flash factory image. It takes few minutes to automatically flash new factory image (please be careful that all previous user data will be lost!).
Step 5. Run! & Check version.
If factory image was successfully flashed, initial setup will start.
After initial setup, you can check your software version by [Home] → [Settings] → [About]. Android Marshmallow is Version 6.0, you can also check Build number is “MRA58K” for Nexus Player.
I also noticed the new category “Android security patch level” is introduced in Android M.
adb, android debugging brige, is used for connecting your PC and Android devices to get log, send command to Android devices etc which is very useful for Android software development.
fastboot command is used to control bootloader mode for Nexus devices, it can be used to flash new factory image etc.
Here the method of how to build adb command and fastboot command manually from Android Open Source Project source code is written. If you feel it trouble some to build adb and fastboot command manually in your PC, see also
Immediately after building, you can find these command by,
$ which fastboot
~/workspaces/aosp/out/host/linux-x86/bin//fastboot
$ which adb
~/workspaces/aosp/out/host/linux-x86/bin//adb
It is better to set environment path (because after this log in session finishes, this path setting will be removed).
# Environment path setting for adb & fastboot
export PATH=~/workspaces/aosp/out/host/linux-x86/bin/:$PATH
Step 5. Check function
Finally you can check if fastboot and adb is working correctly or not.
adb
First is to check adb, connect your PC and Android device by USB. Enable developer mode for your Android device, and after enable USB debugging, type
$ adb devices
It should show device which PC is connecting to. Try sudo if it is not working.
fastboot
Finally check fastboot. Reboot your Nexus devices with bootloader mode
$ adb reboot bootloader
After Nexus reboots with bootloader mode, type
$ fastboot devices
XXXXXXXX fastboot
and check if you can see devices or not. try sudoif it is not working, or it says “waiting for devices” forever. If fastboot is not working, you may need to set up Android device udev rules (refer below links).
Continuing from AsyncTask usage summary. Interest is how to establish independence between Activity and AsyncTask? The answer is well summarized in the article, “Android AsyncTask はバックグラウンドの処理に集中すべし!”. I will just translate and re-summarize this article. 3 ways will be introduced.
Advance – implementation framework of AsyncTask
A. Define as inner class of Activity
Most intuitive, easy and faster way is to implement your AsyncTask inside Activity which use it. It is nice choice when CustomAsyncTask is specific (highly dependent on) to the parent Activity.
Mock implementation is like below, here text of mEditText is updated after AsyncTask’s background process.
public class SomeActivity extends Activity {
private static final String TAG = SomeActivity.class.getSimpleName();
private EditText mEditText;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
mEditText = (EditText) findViewById(R.id.edit_text);
(new CustomAsyncTask()).execute();
}
public class CustomAsyncTask extends AsyncTask<Void, Void, String> {
@Override
protected String doInBackground(Void... params) {
String result = null;
// background process
return result;
}
protected void onPostExecute(String result) {
// Update Activity UI here
mEditText.setText(result);
}
}
}
The problem is that member of Activity, mEditText, is used inside onPostExecute() method of CustomAsyncTask. So this is basically only applicable for this Activity. To separate the work of common AsyncTask part and Activity’s UI update part, we can take following methods. One way is to override methods at Activity, the other way is to implement custom callback.
B. Override UI thread task at Activity side
Consider like this. AsyncTask should concentrate on background task, Activity side will do all UI update task. We can achieve it by overriding UI thread task (onPreExecute, onProgressUpdate and onPostExecute) at Activity.
Mock implementation
public class SomeActivity extends Activity {
private static final String TAG = SomeActivity.class.getSimpleName();
private EditText mEditText;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
mEditText = (EditText) findViewById(R.id.edit_text);
new CustomAsyncTask(){
// Override UI thread methods in Activity
@Override
protected void onPostExecute(String result) {
// Update Activity UI here
mEditText.setText(result);
}
}.execute();
}
}
public class CustomAsyncTask extends AsyncTask<Void, Void, String> {
@Override
protected String doInBackground(Void... params) {
String result = null;
// background process
return result;
}
}
As you can see, CustomAsyncTask only implements doInBackground() method. All other UI update method is implemented in Activity (caller) side. It is a tricky implementation, but it enables us to divide the role of AsyncTask and Activity.
One concern is it has less encapsulation (basically, Activity side can do any UI update based on the result). No common behavior of onPostExecute() is implemented in AsyncTask side, This implementaton may differ among Activities.
C. Register callback to invoke Activity method
The last, most organized way to make AsyncTask independent from Activity is to implement callback. We can reduce dependency between Activity and AsyncTask, but you need to take care about designing callback method types.
Callback methods are implemented as interface in below mock implementation.
import android.os.AsyncTask;
/**
* AsyncTask<Params, Progress, Result>
* Params: Input parameter type
* - arg of {@link #doInBackground}
*
* Progress: Progress parameter type
* - arg of {@link #onProgressUpdate}
*
* Result: Return parameter from background process
* - return type of {@link #doInBackground}
* - arg of {@link #onPostExecute}
*/
public class CustomAsyncTask extends AsyncTask<Void, Void, String> {
private static final String TAG = CustomAsyncTask.class.getSimpleName();
private CustomAsyncTaskCallback mCallback = null;
public CustomAsyncTask(CustomAsyncTaskCallback callback) {
mCallback = callback;
}
@Override
protected void onPreExecute() {
// Initial UI set up here (if necessary)
if(mCallback != null){
mCallback.onPreExecute();
}
}
@Override
protected String doInBackground(Void... params) {
String result = null;
// Implement (maybe long) background process here!
return result;
}
@Override
protected void onProgressUpdate(Void... values) {
// invoked when publishProgress() is called,
}
@Override
protected void onPostExecute(String result) {
// Finally, the result of doInBackground is handled on UI thread here.
if(mCallback != null){
mCallback.onPostExecute(result);
}
}
/** Interface for Activity callback */
public interface CustomAsyncTaskCallback {
void onPreExecute();
void onPostExecute(String result);
/* Add other callback method if necessary */
// void onProgressUpdate();
}
}
To use this callbacks at Activity side, Activity can implement this callback interface. Then, we can implement the function of this callback at Activity side to update UI.
public class SomeActivity extends Activity implements CustomAsyncTask.CustomAsyncTaskCallback {
private static final String TAG = SomeActivity.class.getSimpleName();
private EditText mEditText;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
mEditText = (EditText) findViewById(R.id.edit_text);
new CustomAsyncTask(this).execute();
}
/** CustomAsyncTaskCallback interface implementation */
@Override
public void onPreExecute() {
// This callback is invoked from CustomAsyncTask.onPreExecute()
}
/** CustomAsyncTaskCallback interface implementation */
@Override
public void onPostExecute(String result) {
// This callback is invoked from CustomAsyncTask.onPostExecute()
mEditText.setText(result);
}
}
Summary table
A. Inner class implementation
B. Override UI thread methods
C. Callback implementation
Independent from Activity?
–
✓
✓
Pros
EasyFast
FasterFlexible
Most organized
Cons
The AsyncTask is only for parent Activity
Tricky Haphazard
Strict design is neededTroublesome
Conclusion – which way to use?
Implementation speed is more important. (First implementation, debugging etc)
It is ok that the CustomAsyncTask is only for specific Activity → A. Implement as inner class of Activity
Personal, small team project.
Faster, more flexible, unplanned implementation. → B. Override UI thread task from Activity side
Official, team project.
Specification is designed concretely. → C. Use callback at Activity side
* This is just a personal opinion. Please find yourself which method to adopt for your project.