研究QstileView的加载流程,可以方便后我们后续进行界面的定制化和相应的修改。本文仅仅简单的探究流程,当然我们也会发现好多的新知识。
一、在线代码地址:
分享一个在线看代码的地址:
二、icon和tile的加载流程
三、关于图标布局大小和padding的设置。
QSTileBaseView.java
public QSTileBaseView(Context context, QSIconView icon, boolean collapsedView) {
super(context);
// Default to Quick Tile padding, and QSTileView will specify its own padding.
int padding = context.getResources().getDimensionPixelSize(R.dimen.qs_quick_tile_padding);
//图标的动态添加
mIconFrame = new FrameLayout(context);
mIconFrame.setForegroundGravity(Gravity.CENTER);
//设置大小
int size = context.getResources().getDimensionPixelSize(R.dimen.qs_quick_tile_size);
addView(mIconFrame, new LayoutParams(size, size));
mIcon = icon;
FrameLayout.LayoutParams params = new FrameLayout.LayoutParams(
ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
params.setMargins(0, padding, 0, padding);
mIconFrame.addView(mIcon, params);
mTileBackground = newTileBackground();
if (mTileBackground instanceof RippleDrawable) {
setRipple((RippleDrawable) mTileBackground);
}
setImportantForAccessibility(View.IMPORTANT_FOR_ACCESSIBILITY_YES);
setBackground(mTileBackground);
setPadding(0, 0, 0, 0);
setClipChildren(false);
setClipToPadding(false);
mCollapsedView = collapsedView;
setFocusable(true);
}
dimens.xml
<!--icon外面布局的大小/FrameLayout的-->
<dimen name="qs_quick_tile_size">48dp</dimen>
<!--图标大小-->
<dimen name="qs_tile_icon_size">24dp</dimen>
<!--字体大小-->
<dimen name="qs_tile_text_size">12sp</dimen>