我创建了一个自定义首选项,它嵌入了两个按钮(这里我将Button子类化为FastButton)。问题是执行persistInt来存储首选项会大大减慢按钮的响应。
我的想法是仅在首选项的生命周期结束时才执行persistInt,但是找不到合适的方法来覆盖(即,Preference类没有像onPause()这样的东西)。
在尝试使用AsyncTask将persistInt从UI线程中移出时,我也没有成功。
关于应该如何减轻persistInt对UI响应的影响的任何建议?
public final class StepperPreference extends Preference {
public int mCurrentValue = 1;
public int maxValue = Integer.MAX_VALUE;
public int minValue = Integer.MIN_VALUE;
private TextView mText;
private FastButton plusButton;
private FastButton minusButton;
public StepperPreference(Context context) {
super(context);
}
public StepperPreference(Context context, AttributeSet attrs) {
super(context, attrs);
parseCustomAttributes(attrs);
}
public StepperPreference(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
parseCustomAttributes(attrs);
}
public void setmCurrentValue(int value) {
if (mCurrentValue != value) {
mCurrentValue = value;
persistInt(mCurrentValue);
}
}
private void parseCustomAttributes(AttributeSet attrs) {
int maxValueAttrInt=Integer.MAX_VALUE;
int minValueAttrInt=Integer.MIN_VALUE;
if (attrs!=null) {
TypedArray a=getContext()
.obtainStyledAttributes(attrs,
R.styleable.StepperPreference,
0, 0);
maxValueAttrInt = a.getInt(R.styleable.StepperPreference_maxValue, Integer.MAX_VALUE);
minValueAttrInt = a.getInt(R.styleable.StepperPreference_minValue, Integer.MIN_VALUE);
a.recycle();
}
if (maxValueAttrInt > minValueAttrInt) {
maxValue = maxValueAttrInt;
minValue = minValueAttrInt;
}
}
@Override
protected View onCreateView(ViewGroup parent) {
LayoutInflater li = (LayoutInflater) getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
View view = (View) li.inflate(R.layout.stepper_preference, parent, false);
mText = (TextView) view.findViewById(R.id.text_view);
Context context = getContext();
int localDefaultValue = 0;
mCurrentValue = getPersistedInt(localDefaultValue);
mText.setText(Integer.toString(mCurrentValue));
plusButton = (FastButton) view.findViewById(R.id.plus_button);
plusButton.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
if (mCurrentValue < maxValue) {
mCurrentValue++;
mText.setText(Integer.toString(mCurrentValue));
persistInt(mCurrentValue);
}
}
});
minusButton = (FastButton) view.findViewById(R.id.minus_button);
minusButton.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
if (mCurrentValue > minValue) {
mCurrentValue--;
mText.setText(Integer.toString(mCurrentValue));
persistInt(mCurrentValue);
}
}
});
return view;
}
@Override
protected Object onGetDefaultValue(TypedArray a, int index) {
int localDefaultValue = 0;
Object result = a.getInt(index, localDefaultValue);
return result;
}
@Override
protected void onSetInitialValue(boolean restoreValue, Object defaultValue) {
int localDefaultValue = 0;
setmCurrentValue(restoreValue ? this.getPersistedInt(localDefaultValue) : (int) defaultValue);
}
}
最佳答案
CheckBoxPreference
通过其TwoStatePreference
超类使用persistBoolean()
保存首选项值,就像使用persistInt()
一样。我对CheckBox
的处理没有明显的延迟。这意味着两件事之一:
我是穴居人,无法看到动画等明显的延迟CheckBoxPreference
不会出现您在StepperPreference
中看到的问题
注意:这两种可能性并不互相排斥
如果我们假设#2是正确的,那么还有其他事情要做。方法跟踪(查看您在哪里花费的时间来自persistInt()
的下游)可能对确定StepperPreference
的不同之处很有用。
根据您的评论,您有一个听众响应偏好更改,这就是导致响应缓慢的原因。 “内联”首选项(例如CheckBoxPreference
和StepperPreference
)将比“ cc”和DialogPreference
子类(例如ListPreference
)更“抽搐”,这仅仅是因为更改首选项状态所需的工作较少(例如,一次屏幕点击与2次点击+)。结果,听众需要更便宜。例如,在用户离开PreferenceFragment
之前,您可能会推迟进行大量工作,因此您知道首选项值可能会稳定至少一秒钟左右。