Few things before we start off:
- Not all fonts are compatible with Android
- You need to package the ttf files with your apk
- It's obviously a little bit of extra work
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="fill_parent"
android:layout_height="fill_parent">
<com.beanie.samples.customfont.MyTextViewIn both these classes, we have a method called init() which is called from all the constructors. The method is just 3 line long.
android:layout_marginTop="10dip" android:id="@+id/textView"
android:layout_width="fill_parent" android:layout_height="wrap_content"
android:text="@string/hello" android:textSize="20sp"></com.beanie.samples.customfont.MyTextView>
<com.beanie.samples.customfont.MyButton
android:layout_marginTop="10dip" android:id="@+id/textView"
android:layout_width="fill_parent" android:layout_height="wrap_content"
android:text="@string/hello" android:textSize="20sp"></com.beanie.samples.customfont.MyButton>
</LinearLayout>
if (!isInEditMode()) {Simple!!! You might notice that there is an if condition. This is not required, but it does help when you are preparing your layouts on eclipse, and you need to keep checking if everything's fine. This method, isInEditMode() returns true while eclipses tries to render the view from the XML.
Typeface tf = Typeface.createFromAsset(getContext().getAssets(), "fonts/ds_digib.ttf");
setTypeface(tf);
}
This is what the documentation says:
Indicates whether this View is currently in edit mode. A View is usually in edit mode when displayed within a developer tool. For instance, if this View is being drawn by a visual user interface builder, this method should return true. Subclasses should check the return value of this method to provide different behaviors if their normal behavior might interfere with the host environment. For instance: the class spawns a thread in its constructor, the drawing code relies on device-specific features, etc. This method is usually checked in the drawing code of custom widgets.If you don't put this condition, the layout editor will complain about not being able to set the TypeFace. So, in the layout editor, you will see your TextView and Button widgets with the default font. But, when you run your app on an emulator or a device, you can see the goodness of your custom fonts.
The source code for the sample project can be found here. You can find 3 different fonts (ttf file) in the assets folder to play with.
Hi thank you
ReplyDeleteit workt perfect finnaly a good sample
not like all the shit i found before
Unfortunately too much thing to do, if I want to use fonts in the whole application.
ReplyDeleteFor every single widget a custom widget must be created :(
@Mur Votema: Yeah, actually, it is.
ReplyDeleteis there any way to get the screen resolution during edit mode?
ReplyDeletei'm trying to set the fields of some custom views depending on it , and i wish to see the difference even on design mode.
It doesn't really makes sense, to get the screen resolution during edit mode. The screen can be of any resolution, depending in the device that your application is running on.
ReplyDeletecan you make a tutorial with sample code on how to create a widget with custom font plz ?
ReplyDelete@ShengLong: You can find the source code with a working sample. The link is in the post. Here it goes again.
ReplyDeleteLink to sample
Really very good tutorial..and thank you very much!!!! But i tried using this to my android homescreen widget but its not coming.. As per my knowledge from the search i made they saying like widgets cant have their own fonts cause they dont run in their own process like app. They run in Homescreen's process. So if you know any way to do this in homescreen widget please let me know.
DeleteThanks.
Excellent example. To the point and emminently useful. Many thanks.
ReplyDeleteOn Homescreen widgets, I haven't tried it yet. But I think it wouldn't work.
ReplyDeletehei and thanks or the great example
ReplyDeleteyou mentioned: "You need to package the ttf files with your apk"
so I wonder,
Is there a way for a running android app to download a font and use it ?
Hi Kumar and thanks for the great work.
ReplyDeleteyou mentioned "You need to package the ttf files with your apk"
is there a way for an app to download ttf file and use it while running ?
This is pretty useful stuff.. Thanks
ReplyDeleteHi, this is a useful post. I just want to confirm if do we need to check for the licenses of these fonts before bundling them in our application?
ReplyDeleteYes, I guess so. :)
Delete//Code
ReplyDeletetf4 = Typeface.createFromAsset( getAssets(), "CN_1.TTC");
cn1b.setTypeface(tf4);
Tried with Japanese & chinese fonts not working any solution ?
It always remains blank .. Tried many ttf & ttc fonts ..
How to find which JP & CH fonts are working with droid ..?
I tried with a Japanese font called kirieji.ttf and it worked fine.
DeleteHi,
ReplyDeleteIf i want to support custom font in webview inside our app, it works fine till 4.0 but from 4.0 and higher its not working, any suggestions please this is very urgent requirement.
How did you implement it for the WebView?
Delete