6

为了在我的 中提供自定义字体,我在此处ListActivity编写了一个根据此示例CustomAdapter扩展的类。BaseAdapter

但是,如那里所述,我编写了getView()如下方法:

public View getView(int position, View convertView, ViewGroup parent){
    String gameName = gameNames[position]; // gameName ist the String[] of the Custom Adapter

    TextView tv = new TextView(context);
    tv.setText(gameName);
    tv.setTypeface(Typeface.createFromAsset(context.getAssets(), "fonts/gulim.ttf"));

    return tv;
}

这按预期工作。唯一令人不安的是,列表显示大约需要三到四秒钟(在这种情况下,这是一个很长的时间)。但是,在ListActivity我这样设置onItemClickListeners :

private void setOnItemClickListener(){
    getListView().setOnItemClickListener(new OnItemClickListener() {
        public void onItemClick(AdapterView<?> parent, View view, int pos, long id){
            onClickEntryButton(((TextView) view).getText().toString());
        }
    });
}

private void onClickEntryButton(String gameName){
    Intent intent = new Intent(this, GameActivity.class);
    intent.putExtra("gameName", gameName);
    startActivity(intent);
    finish();
}

现在,当单击 a 时ListItem,需要更多时间才能GameActivity打开。这Activity只是几个TextView从 SQLite 数据库中获取的信息。同样在这里,我为每个TextView. 即使屏幕变黑 2-3 秒(出现应用程序崩溃),也会发生这种情况,然后出现新Activity的。Activity从应用程序的其他地方访问它不会发生这种情况。

在这两种情况下 - 访问ListActivity和访问GameActivityListActivity- 几个

“szipinf - 初始化膨胀状态”

消息出现在 LogCat 中。它们在这种情况下意味着什么?onItemClickListener将s设置getView()为 my 的方法会更好CustomAdapter吗?有些东西似乎真的抑制了转换,但我不知道是什么,因为没有什么大的需要计算或处理(事实上,在 SQLite 数据库中恰好有两个条目,每 5 个字段)?

编辑 如果需要或需要,我当然可以提供更多代码。

4

1 回答 1

4

我有完全相同的问题,你的问题给了我答案!

我仍然不知道确切的根本原因,但这是因为在我的情况下多次从资产中读取自定义字体。如果我的屏幕上有 10 个小部件,并且每个小部件都使用自定义字体,Android 每次都会从资产中加载它。这不仅导致我的活动转换变慢,而且在玩了多个时间后也导致崩溃。

所以我为我的字体创建了一个缓存,以避免每次都从资产中获取字体。

我在我的实用程序类中添加了这段代码:

private static final Hashtable<String, Typeface> cache = new Hashtable<String, Typeface>();

public static final String ASSET_PATH="assetPath";

public static Typeface getFont(Context c, String assetPath) {
    synchronized (cache) {
        if (!cache.containsKey(assetPath)) {
            try {
                Typeface t =(Typeface.createFromAsset(c.getAssets(),
                        "fonts/arial.ttf"));
                cache.put(assetPath, t);
            } catch (Exception e) {
                return null;
            }
        }
        return cache.get(assetPath);
    }
}

我创建了我的自定义类来 setTypeface

public class MyButton extends Button {

public MyButton(Context context, AttributeSet attrs, int defStyle) {
    super(context, attrs, defStyle);
}

public MyButton(Context context, AttributeSet attrs) {
    super(context, attrs);
}

public MyButton(Context context) {
    super(context);
}

@Override
public void setTypeface(Typeface tf) {

    super.setTypeface(Util.getFont(getContext(), Util.ASSET_PATH));
}

}

变量assetPath可用于在运行时提供不同的字体

编辑是我作为库创建的自定义字体管理器,以使其更通用。

于 2014-03-12T10:47:35.137 回答