Esw*_*war 6 java android android-studio material-design android-chips
我需要使用材料设计库以及将通过 API 调用检索的图标动态添加入口芯片。如何使用 Glide 库设置芯片图标?
注意:我之前没有在 drawable 文件夹中保存任何图像。所有数据都是通过 API 调用检索的。
例如,您可以使用此解决方法。定制芯片:
public class GlideChip extends Chip {
public GlideChip(Context context) {
super(context);
}
public GlideChip(Context context, AttributeSet attrs) {
super(context, attrs);
}
/**
* Set an image from an URL for the {@link Chip} using {@link com.bumptech.glide.Glide}
* @param url icon URL
* @param errDrawable error icon if Glide return failed response
*/
public GlideChip setIconUrl(String url, Drawable errDrawable) {
Glide.with(this)
.load(url)
.listener(new RequestListener<Drawable>() {
@Override
public boolean onLoadFailed(@Nullable GlideException e, Object model, Target<Drawable> target, boolean isFirstResource) {
setChipIcon(errDrawable);
return false;
}
@Override
public boolean onResourceReady(Drawable resource, Object model, Target<Drawable> target, DataSource dataSource, boolean isFirstResource) {
setChipIcon(resource);
return false;
}
}).preload();
return this;
}
}
Run Code Online (Sandbox Code Playgroud)
创建 GlideChip,添加到芯片组并启动项目:
public class ChipFragment extends Fragment {
private ChipGroup chipGroup;
public ChipFragment() {
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_chip, container, false);
chipGroup = view.findViewById(R.id.chipGroup);
Chip chip = createChip("John Doe", "https://i1.sndcdn.com/avatars-000197335271-mztyvq-t500x500.jpg");
chipGroup.addView(chip);
return view;
}
private Chip createChip(String name, String avatarUrl) {
GlideChip chip = new GlideChip(getContext());
chip.setText(name);
chip.setIconUrl(avatarUrl, getResources().getDrawable(R.drawable.err_avatar));
chip.setClickable(true);
chip.setFocusable(true);
return chip;
}
}
Run Code Online (Sandbox Code Playgroud)
P/S ... 不要忘记将 Glide 添加到 build.gradle。看这里
归档时间: |
|
查看次数: |
1855 次 |
最近记录: |