gpt4 book ai didi

android - 如何创建 Android Material 设计 UI 小部件?

转载 作者:塔克拉玛干 更新时间:2023-11-02 20:50:31 28 4
gpt4 key购买 nike

我确实阅读了新的 android Material 设计指南,但我无法找到有关如何创建此 UI 小部件(元素)的任何信息。 Gmail、S converter 等应用程序已更新其应用程序以支持新 Material 设计。

我添加了它的截图。 Here is the link to it.由于分数低,我不能放图片。对不起

有什么建议吗??

最佳答案

您在谈论 float 操作按钮。底线是:没有原生的“FAB”小部件(至少目前是这样),它是必须实现的自定义布局。

如果你真的想完全实现 Material Design 应用程序,我建议你看看 Google's 2014 I/O app .他们有一个 FAB 布局的例子 here .

这也是创建一个的代码。从这里gist .

public class FloatingActionButton extends View {

Context context;
Paint mButtonPaint;
Paint mDrawablePaint;
Bitmap mBitmap;
boolean mHidden = false;

public FloatingActionButton(Context context) {
super(context);
this.context = context;
init(Color.WHITE);
}

public void init(int color) {
setWillNotDraw(false);
setLayerType(View.LAYER_TYPE_SOFTWARE, null);

mButtonPaint = new Paint(Paint.ANTI_ALIAS_FLAG);
mButtonPaint.setColor(color);
mButtonPaint.setStyle(Paint.Style.FILL);
mButtonPaint.setShadowLayer(10.0f, 0.0f, 3.5f, Color.argb(100, 0, 0, 0));
mDrawablePaint = new Paint(Paint.ANTI_ALIAS_FLAG);

invalidate();
}

@Override
protected void onDraw(Canvas canvas) {
setClickable(true);
canvas.drawCircle(getWidth() / 2, getHeight() / 2, (float) (getWidth() / 2.6), mButtonPaint);
canvas.drawBitmap(mBitmap, (getWidth() - mBitmap.getWidth()) / 2,
(getHeight() - mBitmap.getHeight()) / 2, mDrawablePaint);
}

@Override
public boolean onTouchEvent(MotionEvent event) {
if (event.getAction() == MotionEvent.ACTION_UP) {
setAlpha(1.0f);
} else if (event.getAction() == MotionEvent.ACTION_DOWN) {
setAlpha(0.6f);
}
return super.onTouchEvent(event);
}

public void setColor(int color) {
init(color);
}

public void setDrawable(Drawable drawable) {
mBitmap = ((BitmapDrawable) drawable).getBitmap();
invalidate();
}

public void hide() {
if (!mHidden) {
ObjectAnimator scaleX = ObjectAnimator.ofFloat(this, "scaleX", 1, 0);
ObjectAnimator scaleY = ObjectAnimator.ofFloat(this, "scaleY", 1, 0);
AnimatorSet animSetXY = new AnimatorSet();
animSetXY.playTogether(scaleX, scaleY);
animSetXY.setInterpolator(new AccelerateInterpolator());
animSetXY.setDuration(100);
animSetXY.start();
mHidden = true;
}
}

public void show() {
if (mHidden) {
ObjectAnimator scaleX = ObjectAnimator.ofFloat(this, "scaleX", 0, 1);
ObjectAnimator scaleY = ObjectAnimator.ofFloat(this, "scaleY", 0, 1);
AnimatorSet animSetXY = new AnimatorSet();
animSetXY.playTogether(scaleX, scaleY);
animSetXY.setInterpolator(new OvershootInterpolator());
animSetXY.setDuration(200);
animSetXY.start();
mHidden = false;
}
}

public boolean isHidden() {
return mHidden;
}

public static class Builder {
private FrameLayout.LayoutParams params;
private final Activity activity;
int gravity = Gravity.BOTTOM | Gravity.RIGHT; // default bottom right
Drawable drawable;
int color = Color.WHITE;
int size = 0;
float scale = 0;

/**
* Constructor using a context for this builder and the
* {@link FloatingActionButton} it creates
* @param context
*/
public Builder(Activity context) {
scale = context.getResources().getDisplayMetrics().density;
// The calculation (value * scale + 0.5f) is a widely used to convert to dps to pixel
// units based on density scale
// see <a href="http://developer.android.com/guide/practices/screens_support.html">
// developer.android.com (Supporting Multiple Screen Sizes)</a>
size = (int) (72 * scale + 0.5f); // default size is 72dp by 72dp
params = new FrameLayout.LayoutParams(size, size);
params.gravity = gravity;

this.activity = context;
}

/**
* Sets the FAB gravity.
*/
public Builder withGravity(int gravity) {
this.gravity = gravity;
return this;
}

/**
* Sets the FAB margins in dp.
*/
public Builder withMargins(int left, int top, int right, int bottom) {
params.setMargins((int) (left * scale + 0.5f), (int) (top * scale + 0.5f),
(int) (right * scale + 0.5f), (int) (bottom * scale + 0.5f));
return this;
}

/**
* Sets the FAB drawable.
*
* @param drawable
*/
public Builder withDrawable(final Drawable drawable) {
this.drawable = drawable;
return this;
}

/**
* Sets the FAB color.
*
* @param color
*/
public Builder withColor(final int color) {
this.color = color;
return this;
}

/**
* Sets the FAB size.
*
* @param size
* @return
*/
public Builder withSize(int size) {
size = (int) (size * scale + 0.5f);
params = new FrameLayout.LayoutParams(size, size);
return this;
}

/**
* Creates a {@link FloatingActionButton} with the
* arguments supplied to this builder.
*/
public FloatingActionButton create() {
final FloatingActionButton button = new FloatingActionButton(activity);
button.setColor(this.color);
button.setDrawable(this.drawable);
params.gravity = this.gravity;
ViewGroup root = (ViewGroup) activity.findViewById(android.R.id.content);
root.addView(button, params);
return button;
}
}

}

然后你会像这样添加:

FloatingActionButton mFab = new FloatingActionButton.Builder(this)
.withColor(getResources().getColor(R.color.accent_color))
.withDrawable(getResources().getDrawable(R.drawable.fab_icon))
.withSize(72)
.withMargins(0, 0, 16, 16)
.create();

关于android - 如何创建 Android Material 设计 UI 小部件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25349317/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com