热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Android27.AndroidStudio9Patch图片制作以及带气泡对话框的制作

9-Patch图片制作在AS中右击图片,然后选择create9-Patchfile,然后在图片当中,左边界和上边界是当图片伸展时所延申的
9-Patch 图片制作

在AS 中右击图片,然后选择create 9-Patch file ,然后在图片当中,左边界和上边界是当图片伸展时所延申的部分,右边界和下边界是其中内容所填充的部分。

对于聊天中的气泡对话框,当然就需要使用9-Patch 文件了,我在这里也提供两个免抠素材:
绿色的:

在这里插入图片描述

这里还有一个白色的(右击,选择保存图片):

在这里插入图片描述

带气泡的对话框

添加依赖

既然是对话框,我们就可能用到RecyclerView,使用RecyclerView 就要添加依赖,具体方法见:
Android >> 26. RecyclerView(一)

编辑对话框主页面

对话框除了各自的信息之外,当然最基本还要有文字输入框以及一个发送按钮:

<LinearLayoutxmlns:android&#61;"http://schemas.android.com/apk/res/android"xmlns:tools&#61;"http://schemas.android.com/tools"android:layout_width&#61;"match_parent"android:layout_height&#61;"match_parent"tools:context&#61;".Chatting_View"android:background&#61;"&#64;color/colorLittleGray"android:orientation&#61;"vertical"><androidx.recyclerview.widget.RecyclerViewandroid:id&#61;"&#64;&#43;id/msg_chatting_recycler_view"android:layout_width&#61;"match_parent"android:layout_height&#61;"wrap_content"android:layout_weight&#61;"1">androidx.recyclerview.widget.RecyclerView><LinearLayoutandroid:layout_width&#61;"match_parent"android:layout_height&#61;"wrap_content"><EditTextandroid:id&#61;"&#64;&#43;id/input_text"android:layout_width&#61;"0dp"android:layout_height&#61;"wrap_content"android:layout_weight&#61;"1"android:hint&#61;"Type something here"android:maxLines&#61;"2"tools:ignore&#61;"Suspicious0dp" /><Buttonandroid:id&#61;"&#64;&#43;id/send_button"android:layout_width&#61;"wrap_content"android:layout_height&#61;"wrap_content"android:text&#61;"Send"/>LinearLayout>
LinearLayout>

我们放置了一个RecyclerView&#xff0c;然后在其下面放置一个文本输入框和一个发送按钮。

编辑RecyclerView 子项

有了对话框的整体布局之后&#xff0c;当然就要编辑一下每个RecyclerView 的消息子项

<LinearLayoutxmlns:android&#61;"http://schemas.android.com/apk/res/android"xmlns:tools&#61;"http://schemas.android.com/tools"android:orientation&#61;"vertical"android:layout_width&#61;"match_parent"android:layout_height&#61;"wrap_content"android:padding&#61;"10dp"><LinearLayoutandroid:id&#61;"&#64;&#43;id/left_layout"android:layout_width&#61;"wrap_content"android:layout_height&#61;"wrap_content"android:layout_gravity&#61;"left"android:background&#61;"&#64;drawable/left_white_msg"tools:ignore&#61;"RtlHardcoded"><TextViewandroid:id&#61;"&#64;&#43;id/left_msg"android:layout_width&#61;"wrap_content"android:layout_height&#61;"wrap_content"android:gravity&#61;"center"android:layout_margin&#61;"10dp"android:textColor&#61;"#000"/>LinearLayout><LinearLayoutandroid:id&#61;"&#64;&#43;id/right_layout"android:layout_width&#61;"wrap_content"android:layout_height&#61;"wrap_content"android:layout_gravity&#61;"right"android:background&#61;"&#64;drawable/right_green_msg"tools:ignore&#61;"RtlHardcoded"><TextViewandroid:id&#61;"&#64;&#43;id/right_msg"android:layout_width&#61;"wrap_content"android:layout_height&#61;"wrap_content"android:gravity&#61;"center"android:layout_margin&#61;"10dp"android:textColor&#61;"#000"/>LinearLayout>
LinearLayout>

&#xff08;在这里&#xff0c;为了美观&#xff0c;将接收和发送的消息分别设置为左对齐和右对齐&#xff09;

为了方便之后的消息类型判断以及显示&#xff0c;我们将一个接收消息框和一个发送消息框作为一个子项体&#xff0c;在后续我们可以通过判断消息是接收进来的还是发送出去的从而选择显示哪个消息&#xff08;setVisibility(View.VISIBLE)&#xff09;&#xff0c;而将另一个消息的控件设置为setVisibility(View.GONE)

定义消息实体类

现在有了对话框的整体布局和每个Item 子项的布局之后&#xff0c;我们就要开始对Item 子项的性质进行设置了。

在Activity 中定义一个消息的类&#xff1a;

public class Msg{public static final int TYPE_RECEIVED &#61; 0;public static final int TYPE_SENT &#61; 1;private String content;private int type;public Msg(String content, int type){this.content &#61; content;this.type &#61; type;}public String getContent(){return content;}public int getType(){return type;}
}

Msg 类中只有两个字段&#xff0c;content 表示消息的内容&#xff0c;type 表示消息的类型&#xff08;TYPE_RECEIVEDTYPE_SENT&#xff09;

创建适配器类

用了RecyclerView&#xff0c;当然就还需要使用适配器了。

同样在Activityjava 文件中

public static class MsgAdapter extends RecyclerView.Adapter<MsgAdapter.ViewHolder>{private List<Msg> mMsglist;static class ViewHolder extends RecyclerView.ViewHolder{LinearLayout leftLayout;LinearLayout rightLayout;TextView leftMsg;TextView rightMsg;public ViewHolder(View view){super(view);leftLayout &#61; view.findViewById(R.id.left_layout);rightLayout &#61; view.findViewById(R.id.right_layout);leftMsg &#61; view.findViewById(R.id.left_msg);rightMsg &#61; view.findViewById(R.id.right_msg);}}public MsgAdapter(List<Msg> msgList){mMsglist &#61; msgList;}&#64;NonNull&#64;Overridepublic ViewHolder onCreateViewHolder(&#64;NonNull ViewGroup parent, int viewType) {View view &#61; LayoutInflater.from(parent.getContext()).inflate(R.layout.msg_item, parent, false);return new ViewHolder(view);}&#64;Overridepublic void onBindViewHolder(&#64;NonNull ViewHolder holder, int position) {Msg msg &#61; mMsglist.get(position);/* 若收到消息&#xff0c;显示左边的消息布局&#xff0c;将右边的消息布局去除 */if(msg.getType() &#61;&#61; Msg.TYPE_RECEIVED){holder.leftLayout.setVisibility(View.VISIBLE);holder.rightLayout.setVisibility(View.GONE);holder.leftMsg.setText(msg.getContent());} /* 若发送消息&#xff0c;则显示右边的消息布局&#xff0c;将左边的消息布局去除 */else if(msg.getType() &#61;&#61; Msg.TYPE_SENT){holder.leftLayout.setVisibility(View.GONE);holder.rightLayout.setVisibility(View.VISIBLE);holder.rightMsg.setText(msg.getContent());}}&#64;Overridepublic int getItemCount() {return mMsglist.size();}
}

使用RecyclerView

现在有了适配器了&#xff0c;可以使用这个RecyclerView

先声明

private List<Msg> msgList &#61; new ArrayList<>();
private EditText inputText;
private Button send;
private RecyclerView msgRecyclerView;
private MsgAdapter adapter;

最后在ActivityonCreate() 方法中进行调用

&#64;Override
protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_chatting__view);initMsgs();inputText &#61; findViewById(R.id.input_text);send &#61; findViewById(R.id.send_button);msgRecyclerView &#61; findViewById(R.id.msg_chatting_recycler_view);LinearLayoutManager layoutManager &#61; new LinearLayoutManager(this);msgRecyclerView.setLayoutManager(layoutManager);adapter &#61; new MsgAdapter(msgList);msgRecyclerView.setAdapter(adapter);send.setOnClickListener(new View.OnClickListener() {&#64;Overridepublic void onClick(View view) {String content &#61; inputText.getText().toString();if(!content.isEmpty()){Msg msg &#61; new Msg(content, Msg.TYPE_SENT);msgList.add(msg);adapter.notifyItemInserted(msgList.size() - 1);msgRecyclerView.scrollToPosition(msgList.size() - 1);inputText.setText("");}}});
}private void initMsgs(){Msg msg1 &#61; new Msg("Hello guy.", Msg.TYPE_RECEIVED);msgList.add(msg1);Msg msg2 &#61; new Msg("Who are you?", Msg.TYPE_SENT);msgList.add(msg2);Msg msg3 &#61; new Msg("I&#39;m Anonymous.", Msg.TYPE_RECEIVED);msgList.add(msg3);
}

我们先在initMsgs() 方法中初始化了几条信息用于显示。
然后配置RecyclerView&#xff0c;添加点击事件。在点击事件中&#xff0c;我们为要发送出去的信息创建一个Msg 对象&#xff0c;然后添加进msgList 列表当中。之后调用适配器的notifyItemInserted() 方法用于通知列表有新的数据插入&#xff0c;这样新增的消息才能够在RecyclerView 中显示。接着调用RecyclerView 的scrollToPosition() 方法将显示的数据滚动到最后一行。最后将文本输入框清空。


在这里插入图片描述


推荐阅读
  • 本文介绍了一种自定义的Android圆形进度条视图,支持在进度条上显示数字,并在圆心位置展示文字内容。通过自定义绘图和组件组合的方式实现,详细展示了自定义View的开发流程和关键技术点。示例代码和效果展示将在文章末尾提供。 ... [详细]
  • 本文探讨了资源访问的学习路径与方法,旨在帮助学习者更高效地获取和利用各类资源。通过分析不同资源的特点和应用场景,提出了多种实用的学习策略和技术手段,为学习者提供了系统的指导和建议。 ... [详细]
  • 本文介绍如何在 Android 中自定义加载对话框 CustomProgressDialog,包括自定义 View 类和 XML 布局文件的详细步骤。 ... [详细]
  • 掌握Android UI设计:利用ZoomControls实现图片缩放功能
    本文介绍了如何在Android应用中通过使用ZoomControls组件来实现图片的缩放功能。ZoomControls提供了一种简单且直观的方式,让用户可以通过点击放大和缩小按钮来调整图片的显示大小。文章详细讲解了ZoomControls的基本用法、布局设置以及与ImageView的结合使用方法,适合初学者快速掌握Android UI设计中的这一重要功能。 ... [详细]
  • 技术分享:深入解析GestureDetector手势识别机制
    技术分享:深入解析GestureDetector手势识别机制 ... [详细]
  • 开发笔记:深入解析Android自定义控件——Button的72种变形技巧
    开发笔记:深入解析Android自定义控件——Button的72种变形技巧 ... [详细]
  • Android 图像色彩处理技术详解
    本文详细探讨了 Android 平台上的图像色彩处理技术,重点介绍了如何通过模仿美图秀秀的交互方式,利用 SeekBar 实现对图片颜色的精细调整。文章展示了具体的布局设计和代码实现,帮助开发者更好地理解和应用图像处理技术。 ... [详细]
  • 为了优化直播应用底部聊天框的弹出机制,确保在不同设备上的布局稳定性和兼容性,特别是在配备虚拟按键的设备上,我们对用户交互流程进行了调整。首次打开应用时,需先点击首个输入框以准确获取键盘高度,避免直接点击第二个输入框导致的整体布局挤压问题。此优化通过调整 `activity_main.xml` 布局文件实现,确保了更好的用户体验和界面适配。 ... [详细]
  • Android目录遍历工具 | AppCrawler自动化测试进阶(第二部分):个性化配置详解
    终于迎来了“足不出户也能为社会贡献力量”的时刻,但有追求的测试工程师绝不会让自己的生活变得乏味。与其在家消磨时光,不如利用这段时间深入研究和提升自己的技术能力,特别是对AppCrawler自动化测试工具的个性化配置进行详细探索。这不仅能够提高测试效率,还能为项目带来更多的价值。 ... [详细]
  • ButterKnife 是一款用于 Android 开发的注解库,主要用于简化视图和事件绑定。本文详细介绍了 ButterKnife 的基础用法,包括如何通过注解实现字段和方法的绑定,以及在实际项目中的应用示例。此外,文章还提到了截至 2016 年 4 月 29 日,ButterKnife 的最新版本为 8.0.1,为开发者提供了最新的功能和性能优化。 ... [详细]
  • 本文探讨了Android系统中支持的图像格式及其在不同版本中的兼容性问题,重点涵盖了存储、HTTP传输、相机功能以及SparseArray的应用。文章详细分析了从Android 10 (API 29) 到Android 11 的存储规范变化,并讨论了这些变化对图像处理的影响。此外,还介绍了如何通过系统升级和代码优化来解决版本兼容性问题,以确保应用程序在不同Android版本中稳定运行。 ... [详细]
  • 深入解析 Android 选择器与形状绘制技术
    本文深入探讨了 Android 中选择器(Selector)与形状绘制(Shape Drawing)技术的应用与实现。重点分析了 `Selector` 的 `item` 元素,其中包括 `android:drawable` 属性的使用方法及其在不同状态下的表现。此外,还详细介绍了如何通过 XML 定义复杂的形状和渐变效果,以提升 UI 设计的灵活性和美观性。 ... [详细]
  • 本文探讨了在Android应用中实现动态滚动文本显示控件的优化方法。通过详细分析焦点管理机制,特别是通过设置返回值为`true`来确保焦点不会被其他控件抢占,从而提升滚动文本的流畅性和用户体验。具体实现中,对`MarqueeText.java`进行了代码层面的优化,增强了控件的稳定性和兼容性。 ... [详细]
  • 深入解析 Android Drawable:第六阶段进阶指南 ... [详细]
  • Android ListView 自定义 CheckBox 实现列表项多选功能详解
    本文详细介绍了在Android开发中如何在ListView的每一行添加CheckBox,以实现列表项的多选功能。用户不仅可以通过点击复选框来选择项目,还可以通过点击列表的任意一行来完成选中操作,提升了用户体验和操作便捷性。同时,文章还探讨了相关的事件处理机制和布局优化技巧,帮助开发者更好地实现这一功能。 ... [详细]
author-avatar
君字翔宇_323
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有