提升Android Studio开发体验:使用Kelp插件实现颜色和图标预览

提升Android Studio开发体验:使用Kelp插件实现颜色和图标预览

在Android开发中,自动补全功能对于提高开发效率至关重要。然而,默认的Android Studio并不能预览颜色和图标,这使得开发者在选择资源时常常感到困惑。本文将介绍如何使用Kelp插件,为Android Studio添加颜色和图标预览功能,从而提升开发体验。

Kelp插件简介

Kelp插件是一款功能强大的工具,旨在为Android Studio添加各种增强功能,改善开发者体验。它支持以下关键功能:

  • 自动补全中的暗色和亮色预览 🎨
  • 自动补全中的图标预览 🔍
  • 组件函数的可自定义图标
  • 可在Git中存储和共享的Live Templates ⌨️
  • KDoc图像渲染等

安装Kelp插件

首先,从Kelp GitHub仓库下载最新版本的插件,并通过以下路径手动安装:

Settings/Preferences > Plugins > ⚙️ > Install plugin from disk....

接下来,创建一个名为config.json的配置文件,放置在.idea/kelp目录中。该文件将用于配置插件的各种功能。此外,为确保团队中的每个人都在使用该插件,您可以创建一个externalDependencies.xml文件进行通知。

注意:确保您使用的是Android Studio Koala 2024.1.1 Canary 3或更高版本。

设置颜色预览 🎨

要启用颜色预览功能,首先需要按照以下方式实现您的颜色系统:

class GetcontactColor(
  val primary: Color,
  val secondary: Color,
) {
  /**
   * This class must have MUST structure and name.
   * It MUST be placed here.
   * You can create it manually or autogenerate it using code generators.
   */
  private class KelpColorPreview {
    /**
     * The pattern is "name_lightColor_darkColor"
     * If you don't have a dark theme, you MUST set `darkColor`
     * to be the same as `lightColor`, then it won't be rendered.
     * 
     * Colors MUST be in ARGB:
     * The format of an ARGB hexadecimal color is AARRGGBB. 
     * AA is the alpha channel. It represents the opacity of the color. 
     * RR is the red value, GG is the green, and BB is the blue.
     * 
     * If your colors are in RGB format, just add FF to them, 
     * representing no transparency.
     */
    val primary_FFD0BCFF_FF6650A4 = Unit
    val secondary_12CCC2DC_FF625B71 = Unit
  }
}

// or it can be declared like this
// it's just important for the color to be a val apperantly.
class GetcontactColor2 {
  private var _primary: Color by mutableStateOf(...)
  val primary: Color = _primary

  private var _secondary: Color by mutableStateOf(...)
  val secondary: Color = _secondary

  private class KelpColorPreview {
    val primary_FFD0BCFF_FF6650A4 = Unit
    val secondary_12CCC2DC_FF625B71 = Unit
  }
}

然后,在config.json文件中添加以下配置,以启用代码补全和gutter预览:

{
  "colorPreview": {
    "codeCompletionEnabled": true,
    "gutterEnabled": true
  }
}

保存config.json文件后,插件将自动应用新的更改。效果如下:

设置图标预览 🔍

图标预览功能使得开发者在使用图标时能够更直观地看到实际效果。我们团队有20多名Android开发者,使用图标时经常会遇到重复问题。通过使用ImageVector这种稳定类型管理图标,我们实现了高效的图标管理。

以下是图标管理的实现示例:

class AwesomeIcon {
    val direction: ImageVector
        @Composable
        get() = ImageVector.vectorResource(id = R.drawable.ic_direction)

    val feedback: ImageVector
        @Composable
        get() = ImageVector.vectorResource(id = R.drawable.ic_feedback)
    // 其他图标定义...
}

internal val LocaleIcon = staticCompositionLocalOf { AwesomeIcon() }

object AwesomeTheme {
    val icons: AwesomeIcon
        @Composable
        @ReadOnlyComposable
        get() = LocaleIcon.current
}

@Composable
fun AwesomeTheme(
    icons: AwesomeIcon = AwesomeTheme.icons,
    content: @Composable () -> Unit,
) {
    CompositionLocalProvider(
        LocaleIcon provides icons,
    ) {
        content()
    }
}

要启用图标预览功能,在config.json文件中添加以下配置:

{
  "iconsRendering": {
    "codeCompletionEnabled": true,
    "gutterEnabled": true,
    "containerClassName": "com.yourpackage.AwesomeIcon"
  }
}

由于插件将类中的图标名称映射到实际资源以进行预览,变量名必须与资源匹配。我们的资源通常以“ic_”开头,因此可以在配置文件中添加映射器:

{
  "iconsRendering": {
    "propertyToResourceMapper": {
      "addPrefix": "ic_",
      "convertToSnakeCase": true
    }
  }
}

保存配置文件后,您将看到图标预览效果:

为设计系统组件添加预览图标


此功能允许您为设计系统的组件添加预览图标,特别适用于拥有大量组件的UI套件。要启用该功能:

  1. .idea/kelp目录中添加一个名为dsComponentFunIcon的40x40 SVG图标。

注意:您还可以选择添加一个名为dsComponentFunIcon_dark.svg的暗色版本。

  1. config.json文件中添加以下配置:
{
  "componentFunHighlighting": {
    "functionFqnPrefix": "app.source.getcontact.uikit.component.",
    "functionSimpleNamePrefix": "Getcontact" // 可选,用于限制仅针对具有特定前缀的组件
  }
}

插件将仅为您提供的包下的可组合组件添加此预览图标。

设置共享Live Templates ⌨️

即使可以通过不同方式实现,Kelp插件使得通过Git共享Live Templates变得更加容易。只需将Live Templates添加到config.json文件中:

{
  "liveTemplates": [
    {
      "abbreviation": "gth",
      "text": "GetcontactTheme.dimensions.$CODE_COMPLETION$",
      "description": "Writes \"GetcontactTheme.\""
    },
    {
      "abbreviation": "gco",
      "text": "GetcontactTheme.colors.$CODE_COMPLETION$",
      "description": "Writes \"GetcontactTheme.colors\""
    },
    {
      "abbreviation": "gty",
      "text": "GetcontactTheme.typography.$CODE_COMPLETION$",
      "description": "Writes \"GetcontactTheme.typography\""
    },
    {
      "abbreviation": "gic",
      "text": "GetcontactTheme.icons.$CODE_COMPLETION$",
      "description": "Writes \"GetcontactTheme.icons\""
    }
    // 其他模板...
  ]
}

保存后,您可以通过Git共享这些模板文件。

结语

Kelp插件为Android Studio带来了诸多强大功能,极大地提升了开发体验。通过本文介绍的方法,您可以轻松设置颜色和图标预览功能,并在设计系统组件中添加预览图标。此外,Kelp插件还提供了便捷的Live Templates共享方式,进一步提高了团队协作效率。

好了,kelp基本功能介绍完毕,下面是kelp的仓库地址。

Github

https://github.com/ozontech/kelp

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/769657.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Linux中cat命令的英文含义

我之前一直在想cat不是猫的意思吗,但是cat命令在Linux中并不是指"猫"这个动物,而是来源于它的功能:concatenate(连接)和typeset(打印)。这个命令的名称是这两个功能的首字母缩写。尽管…

「电子数据」龙信助力鞍山市公安局电子数据取证竞赛

文章关键词:电子数据取证、服务支持、电子数据取证竞赛服务、取证人才培养 为进一步推动电子数据取证分析专业人才队伍建设,不断提高电子数据取证分析能力,7月1日,鞍山市公安局网安支队举办了电子数据取证竞赛,并取得…

【SOLID原则前端中的应用】里氏替换原则(Liskov Substitution Principle,LSP)- vue3示例

里氏替换原则(Liskov Substitution Principle,LSP)规定,子类对象必须能够替换父类对象,并且程序的行为保持不变。 在Vue 3中,这意味着我们在创建可替换的组件时,应该确保子组件能够完全替代父组…

杭州叉车A38老款国二 车辆维修与保养

发动机参数 更换缸垫 故障表现特征: 1. 发动机发动风扇端有异响,喷气 2. 水箱加水后外冒有水气泡 车型: 新柴490B 预估市场平均价格: 25一个 发动机-气门间隙调整 气门间隙大小: 经询问相关师傅,此次调整…

物联网综合实验平台-物联网实验实训教学平台-物联网实验箱

物联网(IoT)是一种连接性技术,将各种设备和物品连接到互联网,通过数据的收集和分析实现更智能的决策和操作。在《“十四五”数字经济发展规划》中,物联网被明确提出,被视为数字经济时代的基础设施。当前&am…

【JavaWeb】利用IntelliJ IDEA 2024.1.4 +Tomcat10 搭建Java Web项目开发环境(图文超详细)

1、启动IntelliJ idea 2024.1.4 在欢迎页面,请确认好版本。因为不同的版本,搭建项目过程不太一样。 点击,新建项目。如图: 2、新建项目 在新建项目界面,选择java,在右侧信息模块内,根据个人情…

C语言中函数的声明和创建

C语言的函数创建和java函数有有一定的区别:如下示例: fun.h文件 fun.c文件 main.c文件 或这简单一点可以这样写, 声明和定义的差异: 函数分类

加速度传感器信号处理注意事项

1 传感器分类 对于压电式压力传感器而言,输出信号是最重要的选择标准之一。压电式压力传感器与电子电路相连,电子电路将传感器产生的电荷成比例转换为电压。 如果选用外部设备(电荷放大器)充当电子元件,则称其为电…

线程池概念的详解

前言👀~ 上一章我们介绍了什么是定时器以及如何去实现一个定时器,今天我们来讲解在多线程中同样很重要的一个内容线程池 线程池的出现 线程池概念 标准库中的线程池 工厂模式 newCacheThreadPool方法 newFixedThreadPool方法 ThreadPoolExecutor…

2024年广东省食品安全管理员考试精选练习题库。

16.食品流通可的单次有效期为()年。 A.2 B.3 C.5 答案:B 17.无公害农产品的标志是()的。 A.绿颜色 B.绿橙两色 答案:B 18.与食品安全有关的"危险温度带"是指适合大多数致病菌增殖的温度…

基于贝叶斯优化的卷积神经网络-循环神经网络混合模型的的模拟股票时间序列预测(MATLAB R2021B)

将机器学习和深度学习方法运用到股市分析中, 不仅具有一定的理论价值, 也具有一定的实践价值。从理论价值上讲, 中国的量化投资技术(投资观念、方法与决策等)还不够成熟, 尚处在起步阶段, 能够将量化投资技术运用到投资决策中的公司寥寥无几。目前, 国内…

初识单片机

单片机 英文 Micro Controller Unit(MCU) 1.内部集成了CPU、RAM、ROM、定时器、中断系统、通讯接口等一系列电脑的常用硬件功能 2.单片机的任务是信息采集(依靠传感器)、处理(依靠CPU)和硬件设备&#…

pycharm无法添加python解释器的解决方法

出现该错误的原因是先前创建过重名的解释器(虚拟环境),在pycharm配置中没有完全删除干净。解决方法如下: 首先在文件->设置界面,找到解释器设置。 然后先按图所示点击全部显示虚拟环境: 接着将无法添…

HTTP基本原理与爬虫

文章目录 HTTP基本原理与爬虫客户端-服务器模型请求和响应示例请求:示例响应: 无状态协议HTTP方法HTTP状态码HTTP/2 和 HTTP/3 HTTP在爬虫中的应用 HTTP基本原理与爬虫 客户端-服务器模型 HTTP(HyperText Transfer Protocol,超文…

基于Python Django的房价数据分析平台,包括大屏和后台数据管理,有线性、向量机、梯度提升树、bp神经网络等模型

背景 随着城市化进程的加速和房地产市场的快速发展,房价已成为经济学、社会学等多学科交叉研究的热点问题。为了更精确地分析和预测房价,数据分析和机器学习技术被广泛应用。在此背景下,开发一个基于Python Django的房价数据分析平台具有重要…

KVB交易平台 :市场迎来新热潮!铜价会持续上涨吗?

近期,全球铜价出现明显上涨趋势。韩国光阳LME仓库的铜库存显著下降,市场对即时需求的增加作出了积极反应。供应端的紧张和需求端的复苏共同推动了铜价的上涨。 KVB外汇 分析师们对未来铜价保持谨慎乐观态度,认为长期内铜价有望保持稳定甚至进…

单元测试总结,一文全通

🍅 视频学习:文末有免费的配套视频可观看 🍅 点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快 一、何为单测 测试有黑盒测试和白盒测试之分,黑盒测试顾名思义就是我们不了解盒子的…

分析Profiler Timeline中的算子序列,通过寻找频繁项集的办法,得到TOPK可融合的算子序列

分析Profiler Timeline中的算子序列,通过寻找频繁项集的办法,得到TOPK可融合的算子序列 1.相关链接2.代码【仅分析带通信算子的Pattern】3.在实际工程中发现 [all_gather, matrix_mm_out]频率最高4.[Ascend MC2](https://gitee.com/ascend/MindSpeed/blob/master/docs/features…

微软关闭中国所有线下店,并不影响全球第一

​关注卢松松,会经常给你分享一些我的经验和观点。 微软没有被时代淘汰,时代也没有告别微软!中国市场对微软可有可无,即便没有中国市场,微软市值也在全球前三,这是事实!a 5月中旬,微软azure解散中国分部…

【C语言入门】初识C语言:掌握编程的基石

📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C语言 “ 登神长阶 ” 🤡往期回顾🤡:C语言入门 🌹🌹期待您的关注 🌹🌹 ❀C语言入门 📒1. 选择…