ant*_*009 12 android android-layout
我想在截图中创建这样的东西.它有一个主要布局,它是覆盖它的背景和布局.我不确定这是怎么做到的.
我最好的猜测是一个对话框片段.这是做这样的事情的正确方法吗?
我尝试使用对话框片段并没有给出我想要的结果,这是我能得到的结果.
这是我的布局:
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:app="http://schemas.android.com/apk/res-auto"
tools:context="com.chatt.fragments.AddMember">
<ImageButton
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ic_highlight_off_white_36dp"
android:layout_alignParentRight="true"
android:layout_alignParentEnd="true"/>
<android.support.design.widget.CoordinatorLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<ImageView
android:id="@+id/ivBackground"
android:layout_width="match_parent"
android:layout_height="300dp"
android:src="@drawable/world"
android:scaleType="centerCrop"
android:alpha="0.4"/>
<de.hdodenhof.circleimageview.CircleImageView
android:id="@+id/civProfilePhoto"
android:layout_width="70dp"
android:layout_height="70dp"
android:src="@drawable/user3"
app:layout_anchor="@+id/ivBackground"
app:layout_anchorGravity="bottom|center"/>
<TextView
android:id="@+id/tvMemberName"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:fontFamily="sans-serif-light"
android:text="Sarah"
android:textSize="26sp"
android:textStyle="bold"
app:layout_anchor="@+id/civProfilePhoto"
app:layout_anchorGravity="bottom|center"
android:layout_marginTop="40dp"/>
</android.support.design.widget.CoordinatorLayout>
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="60dp"
android:layout_alignParentBottom="true"
android:background="@color/material_grey_300">
<ImageButton
android:id="@+id/ibLock"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_alignParentStart="true"
android:layout_alignParentLeft="true"
android:layout_marginLeft="60dp"
android:layout_marginStart="60dp"
android:src="@drawable/ic_lock_black_36dp"/>
<ImageButton
android:id="@+id/ibAddMember"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_alignParentEnd="true"
android:layout_alignParentRight="true"
android:layout_marginRight="60dp"
android:layout_marginEnd="60dp"
android:src="@drawable/ic_person_add_black_36dp"/>
</RelativeLayout>
</RelativeLayout>
Run Code Online (Sandbox Code Playgroud)
我使用协调器布局将背景图片固定在背景上.但是,这很好.但这个名字涵盖了一些个人资料图片.我从谷歌图标包下载的图标.臀部显示非常黑的背景,应该是透明的.右上角的关闭图标也没有透明背景.该对话框覆盖整个屏幕.
我像这样膨胀我的DialogFragment:
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setStyle(DialogFragment.STYLE_NO_FRAME, 0);
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// Inflate the layout for this fragment
getDialog().getWindow().setBackgroundDrawable(new ColorDrawable(0));
return inflater.inflate(R.layout.fragment_add_member, container, false);
}
Run Code Online (Sandbox Code Playgroud)
非常感谢任何建议,
Mat*_*ini 11
这是使用以下代码重新创建屏幕截图UI的布局的一个小示例DialogFragment:
布局fragment_add_member.xml:
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<ImageView
android:layout_width="250dp"
android:layout_height="200dp"
android:scaleType="centerCrop"
android:src="@drawable/world"/>
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="end"
android:layout_margin="5dp"
android:src="@drawable/ic_highlight_off_white_36dp"/>
<de.hdodenhof.circleimageview.CircleImageView
android:id="@+id/civProfilePhoto"
android:layout_width="50dp"
android:layout_height="50dp"
android:layout_gravity="center_horizontal"
android:layout_marginTop="185dp"
android:src="@drawable/profile"/>
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="240dp"
android:gravity="center_horizontal"
android:text="Mattia"
android:textSize="16sp"/>
<FrameLayout
android:layout_width="match_parent"
android:layout_height="60dp"
android:layout_marginTop="320dp"
android:background="@color/material_grey_300">
<ImageView
android:id="@+id/ibLock"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical|start"
android:layout_marginLeft="50dp"
android:layout_marginStart="50dp"
android:src="@drawable/ic_lock_black_36dp"/>
<ImageView
android:id="@+id/ibAddMember"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical|end"
android:layout_marginEnd="50dp"
android:layout_marginRight="50dp"
android:src="@drawable/ic_person_add_black_36dp"/>
</FrameLayout>
</FrameLayout>
Run Code Online (Sandbox Code Playgroud)
的DialogFragment:
public class AddMemberDialogFragment extends DialogFragment {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setStyle(DialogFragment.STYLE_NO_TITLE, 0);
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
return inflater.inflate(R.layout.fragment_add_member, container);
}
}
Run Code Online (Sandbox Code Playgroud)
您可以选择两种方法.
1.使用DialogFragment 它会自动为您提供阴影.
public class OverlayDialogFragment extends DialogFragment {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// This will give you shadow with borderless frame.
setStyle(DialogFragment.STYLE_NO_FRAME, 0);
}
// your code. define layout xml, etc....
}
Run Code Online (Sandbox Code Playgroud)
2.使用重叠的布局和背景可绘制阴影
在根RelativeLayout中定义两个布局,并调整叠加的布局的宽度和高度.然后应用9-patch背景drawable.
<RelativeLayout
android:id="@+id/layoutRoot"
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent">
<!-- your base UI elements here -->
<RelativeLayout
android:id="@+id/overlayLayout"
android:layout_width="600dp"
android:layout_height="800dp"
android:background="@drawable/img_bg_mask"
android:orientation="vertical">
</RelativeLayout>
</RelativeLayout>
Run Code Online (Sandbox Code Playgroud)
而img_bg_mask.png看起来如下.下图显示圆角作为示例,但您可以制作具有矩形阴影的9补丁图像.
| 归档时间: |
|
| 查看次数: |
1095 次 |
| 最近记录: |