亚洲欧美v国产一区二区三区,中文字日产幕乱五区,综合亚洲,,,色,亚洲伊人久久大香线蕉综合,亚洲综合精品伊人久久

首頁 > SEO動態(tài) > 網(wǎng)站技術(shù)SVG圖標(biāo)的高級用法,讓你界面適配效率翻一倍!

SVG圖標(biāo)的高級用法,讓你界面適配效率翻一倍!

SVG 格式圖標(biāo)在軟件界面中有廣泛應(yīng)用,它與生俱來的矢量屬性,使其在高分辨率屏幕上的表現(xiàn)非常完美。SVG 是一個基于 XML 標(biāo)記語言的開放網(wǎng)絡(luò)標(biāo)準(zhǔn)格式,擁有跨設(shè)備多平臺的兼容效果。前面我們有分享過一篇關(guān)于 WPS 圖標(biāo)的文章《探索 WPS 3000 個圖標(biāo)設(shè)計背后的故事》,得到了很多網(wǎng)友的積極反饋。相信界面設(shè)計的小伙伴們都很熟悉 SVG 格式了,這次,我有一個棒的想法想分享給大家:利用 SVG 圖標(biāo)套色,來完成不同界面的適配。

什么是 SVG 圖標(biāo)套色?

圖標(biāo)套色的簡單來說就是利用 SVG 格式的文本屬性,使用 XML 格式標(biāo)準(zhǔn),在 SVG 文檔中增加 CSS 樣式,通過修改 CSS 樣式屬性,精準(zhǔn)控制 SVG 格式圖標(biāo)顏色,通過修改透明度控制圖形顯示與否,從而變換圖標(biāo)的風(fēng)格外觀。

SVG圖標(biāo)的高級用法,讓你界面適配效率翻一倍!

基本原理:修改 SVG 的樣式,生成不同風(fēng)格的圖標(biāo)

SVG圖標(biāo)的高級用法,讓你界面適配效率翻一倍!

用處一:顏色適配

這里有幾個插件,都用到了"保存"、"打印"這些功能。因為主題色不同,即使是同樣外形的圖標(biāo),還是需要根據(jù)主題色的不同輸出適配各個插件的圖標(biāo)。采用圖標(biāo)套色的方法,就可以避免這類圖標(biāo)資源的重復(fù)輸出。

SVG圖標(biāo)的高級用法,讓你界面適配效率翻一倍!

相同功能需要兩套不同主題色的圖標(biāo)

用處二:皮膚適配

現(xiàn)在多數(shù)軟件一般都有皮膚功能,不同用戶需求,衍生出風(fēng)格各異的皮膚,各種顏色,深淺不一,一套圖標(biāo)滿足不了所有,為了視覺效果需要對每個皮膚輸出特定顏色、風(fēng)格的圖標(biāo)。圖標(biāo)數(shù)量如果很多,投入的成本將隨皮膚數(shù)量呈幾何倍增加,圖標(biāo)套色就可以很好的解決這類問題,只需要通過修改圖標(biāo)顏色和風(fēng)格即可適配。

SVG圖標(biāo)的高級用法,讓你界面適配效率翻一倍!

通過修改映射配置,可以得到不同顏色的圖標(biāo)

套色方法

我們先看看圖標(biāo)套色之后的效果:

SVG圖標(biāo)的高級用法,讓你界面適配效率翻一倍!

修改映射配置,可以得到線、面不同風(fēng)格的圖標(biāo)

簡單來說,實現(xiàn)這種效果有下方五個步驟:

SVG圖標(biāo)的高級用法,讓你界面適配效率翻一倍!

套色方法五個步驟

以下方幾個圖標(biāo)來做示例:

SVG圖標(biāo)的高級用法,讓你界面適配效率翻一倍!

SVG 示例圖標(biāo)

第一步,確定圖標(biāo)線、面風(fēng)格

設(shè)計師將圖標(biāo)線、面風(fēng)格確定下來,并保證兩者效果上可以兼容,即輪廓一致。

SVG圖標(biāo)的高級用法,讓你界面適配效率翻一倍!

同時兼容線、面兩種風(fēng)格效果

第二步,定義圖標(biāo)顏色

在確定了圖標(biāo)的風(fēng)格之后,將圖標(biāo)中用到的 7 種顏色,根據(jù)一深一淺再拆分為 14 種(具體幾種顏色可根據(jù)圖標(biāo)設(shè)計需要來定),深色用于填充線性圖形,淺色用于填充面性圖形。

SVG圖標(biāo)的高級用法,讓你界面適配效率翻一倍!

根據(jù)線、面風(fēng)格需要,定義圖標(biāo)的顏色

第三步,給顏色定義樣式名

給 14 種顏色,分別定義好 CSS 樣式名(樣式名遵循 CSS 規(guī)則即可)。

SVG圖標(biāo)的高級用法,讓你界面適配效率翻一倍!

給顏色定義樣式名

第四步,給 SVG 圖標(biāo)添加 CSS 內(nèi)部樣式

SVG 格式圖標(biāo)默認(rèn)是沒有 CSS 樣式,需要手動將 CSS 內(nèi)部樣式添加到 SVG 文檔中,并將 SVG 路徑顏色與 CSS 樣式名關(guān)聯(lián)起來。

SVG圖標(biāo)的高級用法,讓你界面適配效率翻一倍!

給 SVG 添加 CSS 樣式

第五步,樣式屬性配置機(jī)制

添加內(nèi)部樣式之后,需要開發(fā)小哥哥在軟件中增加對 SVG 圖標(biāo) CSS 樣式屬性的映射機(jī)制。修改映射機(jī)制配置文件中 CSS 樣式屬性,就可以控制圖標(biāo)風(fēng)格變化。

SVG圖標(biāo)的高級用法,讓你界面適配效率翻一倍!

修改配置代碼即可改變圖標(biāo)顏色

完成了以上五個步驟,通過修改軟件中的映射機(jī)制配置文件,就可以改變圖標(biāo)風(fēng)格。

應(yīng)用案例

了解了步驟方法,我們以 WPS 為例來講解圖標(biāo)套色在實際案例中的應(yīng)用:

案例一:前面有提到我們的四大組件,WPS 由文字、表格、演示、PDF 四組件組成。每個組件都有各自的主題色,文字主題色為藍(lán)色,表格綠色,演示橘黃色,PDF 紅色。多數(shù)圖標(biāo)都含有主題色,但外形是一樣的,因各組件主題色不同而導(dǎo)致了很多圖標(biāo)的重復(fù)輸出。

套色用處之一的顏色適配,可以讓圖標(biāo)變色以適應(yīng)不同的組件色,避免圖標(biāo)的重復(fù)。

SVG圖標(biāo)的高級用法,讓你界面適配效率翻一倍!

不同主題色圖標(biāo)的變換效果

案例二:WPS 有推出多個風(fēng)格各異的皮膚,因為圖標(biāo)數(shù)量的關(guān)系,無法每個皮膚都輸出一套圖標(biāo),目前只能使用默認(rèn)的線性圖標(biāo)。也因時間和維護(hù)成本而導(dǎo)致圖標(biāo)風(fēng)格的單一。

套色用處之二的皮膚適配,能使圖標(biāo)改變風(fēng)格以適應(yīng)不同的皮膚,既能滿足圖標(biāo)風(fēng)格多樣,又能滿足時間和維護(hù)成本的可控。

SVG圖標(biāo)的高級用法,讓你界面適配效率翻一倍!

不同風(fēng)格圖標(biāo)的變換效果

案例三:深色模式的配色與淺色模式大相徑庭,圖標(biāo)使用的顏色也截然不同,適配需要輸出兩套圖標(biāo)資源,因不同深淺色模式而導(dǎo)致的圖標(biāo)資源重復(fù)輸出。WPS 組件功能區(qū)的圖標(biāo)有幾千個,輸出和維護(hù)都很費精力。

套色用處之二的皮膚適配,在深淺色模式下也能適用,改變圖標(biāo)顏色以適應(yīng)不同的深淺色模式,避免圖標(biāo)的重復(fù)輸出。

SVG圖標(biāo)的高級用法,讓你界面適配效率翻一倍!

深淺色模式下圖標(biāo)的變換效果

總結(jié)

通過以上的案例不難發(fā)現(xiàn),SVG 圖標(biāo)套色技術(shù)的價值,主要有以下幾個方面:

SVG圖標(biāo)的高級用法,讓你界面適配效率翻一倍!

1. 時間和維護(hù)成本的降低

利用圖標(biāo)套色方法,設(shè)計師只需要輸出一套圖標(biāo)資源,就完成了多組件、多風(fēng)格、深淺色模式適配。開發(fā)小哥哥也可以刪掉適配用的冗余代碼,提升了圖標(biāo)的管理和軟件運行效率;

2. 個性化需求的滿足

后期可以增加自定義擴(kuò)展,讓用戶配置圖標(biāo)風(fēng)格,更好地滿足個性化需求;

3. 服務(wù)器資源的節(jié)約

更少圖標(biāo)資源,更小壓縮包,更少空間和寬帶的占用。

采用新技術(shù),幫助設(shè)計、開發(fā)更好地完成多場景適配,降低了整體流程的執(zhí)行難度,為項目節(jié)省了大量時間,避免過多精力投入在重復(fù)工作中,為最終完成目標(biāo)創(chuàng)造了有利條件。同時也解放了生產(chǎn)力,有了更多的時間可以去關(guān)注高價值的項目。

工作中經(jīng)常能遇到重復(fù)的內(nèi)容,這都有提升和優(yōu)化的空間,尋找更高效的方法,讓工作變得輕松簡單。

記得關(guān)注我們,下次還有更多好玩、有趣的內(nèi)容分享給你~

作者:CED設(shè)計團(tuán)隊

想了解更多網(wǎng)站技術(shù)的內(nèi)容,請訪問:網(wǎng)站技術(shù)

本文來源:http://www.sonygallery.com.cn/seodongtai/17496.html

免責(zé)聲明:部分文章信息來源于網(wǎng)絡(luò)以及網(wǎng)友投稿,本網(wǎng)站只負(fù)責(zé)對文章進(jìn)行整理、排版、編輯,是出于傳遞更多信息之目的,并不意味著贊同其觀點或證實其內(nèi)容的真實性,不承擔(dān)任何法律責(zé)任。