码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Flutter 气泡效果 centerSlice 实现点9图


    背景

    点9图,作为控件背景时,用于缩放图片指定区域,而不是默认对整图进行缩放。
    一般用于聊天气泡,这种内容会变更的场景。

    举例

    UI最终效果如下图
    需求: 内容可变,顶部三角不可拉伸,其他区域可以拉伸。
    在这里插入图片描述
    实际图片是105*71的图
    在这里插入图片描述

    Android使用.9图实现该功能

    该需求用.9图 在AndroidStudio创建时:
    在这里插入图片描述

    • 左侧黑线:上下的拉伸区域。
    • 顶部黑线:左右的拉伸区域
    • 右部黑线:填充内容区域的上下限制(如 文本组件的文字)
    • 底部黑线:填充内容区域的左右限制

    右部、底部的黑线可以拉满,然后用组件的 padding 属性达到同样的效果。

    Flutter实现该效果

    Flutter 设置上图的 粉色四边形区域,来描述拉伸区域。

    坐标的数值可以通过 AndroidStudio,移动光标 获取右下角的X、Y数值确定(上图,右下叫红框区域)

    全部代码:

    Container(
            margin: const EdgeInsets.only(top: 6),
            padding: const EdgeInsets.only(left: 12, right: 12, top: 24, bottom: 12),
            decoration: BoxDecoration(
              image: DecorationImage(
                centerSlice: const Rect.fromLTRB(60, 27, 85, 53),
                image: NetworkImage(url),
              )
            ),
            child:
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    下图强调下:
    在这里插入图片描述

    关键代码:

    centerSlice: const Rect.fromLTRB(60, 27, 85, 53),
    
    • 1

    四个数值,就是粉色四边形的 top、left、right、button。
    还有指定一个点,再设置宽、高的方法。

    问题 原始图片太大,导致未缩放也很大:

    如果原始图片就很大, 不压缩的部分,不扩大 也显的大。

    通过设置 一定比例的宽或高,再设置同比例的 centerSlice,就ok了。

    Container(
            // margin: const EdgeInsets.only(top: 6),
            padding: const EdgeInsets.only(left: 12, right: 12, top: 24, bottom: 12),
            decoration: BoxDecoration(
                image: DecorationImage(
                  centerSlice: const Rect.fromLTRB(60 * 0.5,  27*0.5,  85*0.5,  53*0.5),
                  image: NetworkImage(url),
                  width: 105*0.5
                )
            ),
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
  • 相关阅读:
    [Golang] json.Marshal问题总结
    如何使用远程Linux虚拟机的图形界面
    .NET 缓存:内存缓存 IMemoryCache、分布式缓存 IDistributedCache(Redis)
    金山云:基于 JuiceFS 的 Elasticsearch 温冷热数据管理实践
    MYSQL触发器
    PDF文件标题修改方法
    【智能家居项目】FreeRTOS版本——将裸机程序改造成FreeRTOS程序 | DHT11温湿度传感器
    jsp人事考勤管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目
    零数科技深度参与信通院隐私计算金融场景标准制定
    Spring是如何解决循环依赖问题的及三级缓存的作用
  • 原文地址:https://blog.csdn.net/zhjali123/article/details/125567766
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号