在MaterialDrawer庫中獲取自定義行爲的最簡潔的實現是創建您自己的Custom DrawerItem。
快速瀏覽一下DividerDrawerItem
這是項目中最簡單的DrawerItems
如何做到這一點。
在你的情況下,你想修改ToggleDrawerItem。只需複製代碼並將其修改爲您的需要即可。
public class ToggleDrawerItem extends BasePrimaryDrawerItem<ToggleDrawerItem> {
private boolean toggleEnabled = true;
private boolean checked = false;
private OnCheckedChangeListener onCheckedChangeListener = null;
public ToggleDrawerItem withChecked(boolean checked) {
this.checked = checked;
return this;
}
public ToggleDrawerItem withToggleEnabled(boolean toggleEnabled) {
this.toggleEnabled = toggleEnabled;
return this;
}
public ToggleDrawerItem withOnCheckedChangeListener(OnCheckedChangeListener onCheckedChangeListener) {
this.onCheckedChangeListener = onCheckedChangeListener;
return this;
}
public boolean isChecked() {
return checked;
}
public void setChecked(boolean checked) {
this.checked = checked;
}
public boolean isToggleEnabled() {
return toggleEnabled;
}
public void setToggleEnabled(boolean toggleEnabled) {
this.toggleEnabled = toggleEnabled;
}
public OnCheckedChangeListener getOnCheckedChangeListener() {
return onCheckedChangeListener;
}
public void setOnCheckedChangeListener(OnCheckedChangeListener onCheckedChangeListener) {
this.onCheckedChangeListener = onCheckedChangeListener;
}
@Override
public String getType() {
return "TOGGLE_ITEM";
}
@Override
@LayoutRes
public int getLayoutRes() {
return R.layout.material_drawer_item_toggle;
}
@Override
public void bindView(RecyclerView.ViewHolder holder) {
//get our viewHolder
final ViewHolder viewHolder = (ViewHolder) holder;
//bind the basic view parts
bindViewHelper((BaseViewHolder) holder);
if (!isSelectable()) {
viewHolder.view.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (toggleEnabled) {
viewHolder.toggle.setChecked(!viewHolder.toggle.isChecked());
}
}
});
}
viewHolder.toggle.setChecked(checked);
viewHolder.toggle.setOnCheckedChangeListener(checkedChangeListener);
viewHolder.toggle.setEnabled(toggleEnabled);
//call the onPostBindView method to trigger post bind view actions (like the listener to modify the item if required)
onPostBindView(this, holder.itemView);
}
@Override
public ViewHolderFactory getFactory() {
return new ItemFactory();
}
public static class ItemFactory implements ViewHolderFactory<ViewHolder> {
public ViewHolder factory(View v) {
return new ViewHolder(v);
}
}
private static class ViewHolder extends BaseViewHolder {
private ToggleButton toggle;
private ViewHolder(View view) {
super(view);
this.toggle = (ToggleButton) view.findViewById(R.id.material_drawer_toggle);
}
}
private CompoundButton.OnCheckedChangeListener checkedChangeListener = new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
checked = isChecked;
if (getOnCheckedChangeListener() != null) {
getOnCheckedChangeListener().onCheckedChanged(ToggleDrawerItem.this, buttonView, isChecked);
}
}
};
}
更先進的,但簡單的解決方法是將onPostBindView
監聽器添加到您要修改,並使用參考視圖來搜索material_drawer_toggle
(ToggleButton) view.findViewById(R.id.material_drawer_toggle);
這也將讓該項目的根據需要修改和設置此按鈕。
你必須用你自己的drawable替換背景。 – Bhargav
把你自己的'state_off.xml'和'state_on.xml'放在'drawable'文件夾中 –
state_off和state_on是我的drawable -....文件夾中的png圖標。爲什麼我需要將它們更改爲* .xml? –