图片凸出 android,Android图片突出

这篇博客介绍了如何使用Android的layer-list资源文件创建一个带有图片凸出效果的背景。作者通过设置三个item来实现这一效果,分别是顶部透明区域、有色值的底部区域和中间的凸出图片。在布局中应用此背景后,还需调整EditText的margin以避免图片覆盖。最后,为了使dialog背景透明,需要修改dialog窗口的背景色为透明。
摘要由CSDN通过智能技术生成

概述

今天有个群友问 Android 图片凸出 效果怎么弄,早以前有过类似的需求,整个项目的提示框都是一个背景,背景上方有凸出半张图片,所以用layer-list写了一个背景来实现

随便画了一下比较丑,大概就是这个样子了,从上图中应该不难看出,有三个部分,顶部为透明的,底部是有色值的,那个六角星就是凸出来的图片。

那么就来动手呗,新建一个资源文件,用layer-list属性,里面用三个item,第一个item设置高度为30dp,第二个item设置top为30dp,就刚好是个垂直布局,第三个item包含一个bitmap标签,作用是为了保持图片的原大小。

代码

layer-list背景<?xmlversion ="1.0"encoding="utf-8"?>

android:gravity="center_horizontal|top"

android:src="@mipmap/ic_sync"/>

layout 设置根节点背景 android:background="@drawable/bg_money_dialog"<?xmlversion ="1.0"encoding="utf-8"?>

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:background="@drawable/bg_money_dialog"

android:orientation="vertical">

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:gravity="center_horizontal"

android:hint="请输入提现金额"/>

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:gravity="center_horizontal"

android:hint="请输入提现密码"/>

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_gravity="center_horizontal"

android:text="确认"/>

dialogFragment代码publicclassCheckoutMoneyDialogextendsDialogFragment {

@Override

publicDialog onCreateDialog(Bundle savedInstanceState) {

AlertDialog.Builder builder = newAlertDialog.Builder(getActivity());

LayoutInflater inflater = getActivity().getLayoutInflater();

View view = inflater.inflate(R.layout.fragment_checkout_money_dialog, null);

builder.setView(view);

Dialog dialog = builder.create();

returndialog;

}

}

效果不佳,可能需要把 EditText 设置一下 layout_marginTop

layout_marginTop="100dp" 后确实图片没有叠在 EditText 之上,可顶部还是没有透明效果,这个原因是由于dialog背景引起的,需然layout透明,可dialog自身也是有背景的,我们把dialog背景透明一下Dialog dialog = builder.create();

Window window = dialog.getWindow();

window.setBackgroundDrawableResource(android.R.color.transparent);

returndialog;

Matlab中的形态学处理主要用于对二值图像进行操作,包括腐蚀、膨胀、开运算、闭运算、形态学梯度、顶帽和底帽等操作。 1. 腐蚀操作 腐蚀操作可以去除二值图像中的小孔洞和突出部分,使图像变得更加紧凑。在Matlab中,可以使用函数imerode实现腐蚀操作。例如,对一个二值图像进行腐蚀操作的代码如下: ```matlab % 读取二值图像 img = imread('binary_image.png'); % 定义腐蚀结构元素 se = strel('square', 3); % 对图像进行腐蚀操作 eroded_img = imerode(img, se); % 显示腐蚀后的图像 imshow(eroded_img); ``` 2. 膨胀操作 膨胀操作可以填补二值图像中的小孔洞和凸出部分,使图像变得更加平滑。在Matlab中,可以使用函数imdilate实现膨胀操作。例如,对一个二值图像进行膨胀操作的代码如下: ```matlab % 读取二值图像 img = imread('binary_image.png'); % 定义膨胀结构元素 se = strel('square', 3); % 对图像进行膨胀操作 dilated_img = imdilate(img, se); % 显示膨胀后的图像 imshow(dilated_img); ``` 3. 开运算操作 开运算操作是先进行腐蚀操作,再进行膨胀操作,可以去除二值图像中的小孔洞,同时保留图像的边缘特征。在Matlab中,可以使用函数imopen实现开运算操作。例如,对一个二值图像进行开运算操作的代码如下: ```matlab % 读取二值图像 img = imread('binary_image.png'); % 定义开运算结构元素 se = strel('square', 3); % 对图像进行开运算操作 opened_img = imopen(img, se); % 显示开运算后的图像 imshow(opened_img); ``` 4. 闭运算操作 闭运算操作是先进行膨胀操作,再进行腐蚀操作,可以填补二值图像中的小孔洞,同时保留图像的边缘特征。在Matlab中,可以使用函数imclose实现闭运算操作。例如,对一个二值图像进行闭运算操作的代码如下: ```matlab % 读取二值图像 img = imread('binary_image.png'); % 定义闭运算结构元素 se = strel('square', 3); % 对图像进行闭运算操作 closed_img = imclose(img, se); % 显示闭运算后的图像 imshow(closed_img); ``` 5. 形态学梯度操作 形态学梯度操作是通过对图像进行膨胀和腐蚀操作,得到图像中物体的边缘特征。在Matlab中,可以使用函数imgradient实现形态学梯度操作。例如,对一个二值图像进行形态学梯度操作的代码如下: ```matlab % 读取二值图像 img = imread('binary_image.png'); % 定义形态学梯度结构元素 se = strel('square', 3); % 对图像进行膨胀操作 dilated_img = imdilate(img, se); % 对图像进行腐蚀操作 eroded_img = imerode(img, se); % 计算形态学梯度 gradient_img = dilated_img - eroded_img; % 显示形态学梯度图像 imshow(gradient_img); ``` 6. 顶帽和底帽操作 顶帽和底帽操作可以用于图像的背景估计和去除。顶帽操作是原图像和开运算后的图像之差,表示了原图像中的小尺度结构;底帽操作是闭运算后的图像和原图像之差,表示了原图像中的大尺度结构。在Matlab中,可以使用函数imtophat和imbothat实现顶帽和底帽操作。例如,对一个二值图像进行顶帽和底帽操作的代码如下: ```matlab % 读取二值图像 img = imread('binary_image.png'); % 定义顶帽和底帽结构元素 se = strel('square', 3); % 对图像进行顶帽操作 tophat_img = imtophat(img, se); % 对图像进行底帽操作 bothat_img = imbothat(img, se); % 显示顶帽和底帽图像 subplot(1, 3, 1); imshow(img); title('Original Image'); subplot(1, 3, 2); imshow(tophat_img); title('Top Hat Image'); subplot(1, 3, 3); imshow(bothat_img); title('Bottom Hat Image'); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值