2015-04-02 5 views
1

В BaseGameActivity.java У меня есть методы, которые легко создают шрифт. Но почему-то приложение перестает, к сожалению, когда дело доходит до создания шрифта. Код не содержит синтаксическую ошибку.Повреждения типа «К сожалению (имя приложения) остановлено»

BaseGameActivity.java

public class BaseGameActivity extends Activity { 

private Map<String,Typeface> typefaces = new HashMap<String,Typeface>(); 

protected void addTypeface(String name) { 
    Typeface typeface = Typeface.createFromAsset(getAssets(), name+".tff"); 
    typefaces.put(name, typeface); 
} 

protected void setTypeface(TextView v, String typefaceName) { 
    Typeface t = typefaces.get(typefaceName); 
    if(t != null) { 
     v.setTypeface(t); 
    } 
} 

MainAcitivity.java

public class MainActivity extends BaseGameActivity { 

private static final String FONTNAME = "airmole"; 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 
    addTypeface(FONTNAME); 
    setTypeface((TextView) findViewById(R.id.title), FONTNAME); 
} 
} 

Файл airmole.tff находится в папке assets.

LogCat

Caused by: java.lang.RuntimeException: native typeface cannot be made 
     at android.graphics.Typeface.<init>(Typeface.java:319) 
     at android.graphics.Typeface.createFromAsset(Typeface.java:293) 
     at de.ucarweb.tools.BaseGameActivity.addTypeface(BaseGameActivity.java:23) 
     at de.ucarweb.silverball.MainActivity.onCreate(MainActivity.java:28) 
     at android.app.Activity.performCreate(Activity.java:5372) 
     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1104) 
     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2257) 

at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2349) 
            at android.app.ActivityThread.access$700(ActivityThread.java:159) 
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1316) 
            at android.os.Handler.dispatchMessage(Handler.java:99) 
            at android.os.Looper.loop(Looper.java:176) 
            at android.app.ActivityThread.main(ActivityThread.java:5419) 
            at java.lang.reflect.Method.invokeNative(Native Method) 
+0

Что 'logcat' сказать, когда он выходит из строя? – DigitalNinja

+0

Перезагрузите страницу. – Ucar

+1

Отметьте [это] (http://stackoverflow.com/questions/12766930/native-typeface-cannot-be-made-only-for-some-people) и [это] (http://stackoverflow.com/ вопросы/20049643/runtimeexception-native-typeface-не могут быть сделаны) – DigitalNinja

ответ

-1

Обычно вы должны сделать что-то вроде этого:

Typeface typeface = Typeface.createFromAsset(getContext().getAssets(), name+".tff"); 
+1

Как это отличается от того, что находится в вопросе? Он добавляет getContext(), но код находится в Activity, который уже является контекстом. Это не отвечает на вопрос. –

+0

Несколько решений были решены благодаря этому решению. Вы можете проверить пример здесь: [в другом случае о getAssets()] [1] Или вы можете документации есть: [Документация] [2] [1]: http://stackoverflow.com/ Вопросы/18436703/android-typeface-createfromasset [2]: http://developer.android.com/reference/android/app/Dialog.html#getContext –

+0

Первая ссылка о getAssets() недоступна в представлении, вторая - ссылка на api docs для Dialog. Здесь не применяется, размещенный код находится внутри _Activity_ –