我需要创建一个带有白色边框并填充纯色(蓝色或灰色)的FAB。
XML
<android.support.design.widget.FloatingActionButton
android:id="@+id/myFab"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"/>
我尝试了How to change android design support library FAB Button border color?中建议的已接受解决方案。但没有工作(没有添加边框)。
任何帮助都会非常感激。
答案 0 :(得分:3)
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/rl_content_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@android:color/black">
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
android:background="@drawable/circle_white_border"
android:padding="3dp">
<android.support.design.widget.FloatingActionButton
android:id="@+id/fab_btn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical"
android:elevation="0dp"
app:elevation="0dp"
app:fabSize="normal" />
</LinearLayout>
</RelativeLayout>
浮动操作按钮的背景
in the drawable fab_border.xml
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:innerRadius="0dp"
android:shape="ring"
android:thicknessRatio="2"
android:useLevel="false">
<stroke
android:width="4dp"
android:color="@android:color/white" />
</shape>
答案 1 :(得分:0)
drawable
circle_white_border.xml
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:innerRadius="0dp"
android:shape="ring"
android:thicknessRatio="2"
android:useLevel="false" >
<solid android:color="@android:color/transparent" />
<stroke
android:width="3dp"
android:color="@android:color/white" />
</shape>
布局中的浮动操作按钮
<android.support.design.widget.FloatingActionButton
android:id="@+id/myFab"
android:background="@drawable/circle_white_border"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"/>
答案 2 :(得分:0)
您可以通过以下方式编辑:
ImageButton iV = (ImageButton) findViewById(R.id.myFab);
int strokeWidth = 5;
int strokeColor = Color.parseColor("#03dc13");
int fillColor = Color.parseColor("#ff0000");
GradientDrawable gD = new GradientDrawable();
gD.setColor(fillColor);
gD.setShape(GradientDrawable.OVAL);
gD.setStroke(strokeWidth, strokeColor);
iV.setBackground(gD);
根据您的要求更改颜色。