HarmonyOS 鸿蒙Next版本实战 - 溢彩美妆App(1)

发布于 1周前 作者 htzhanglong 来自 鸿蒙OS

HarmonyOS 鸿蒙Next版本实战 - 溢彩美妆App(1)

本帖使用HarmonyOS NEXT,展示一个化妆品在线商店的App首页:溢彩美妆App。

注意:本文不涉及App上的用户互动,仅为页面设计效果的实现。

目录

设计预览

下图是在设计软件中的效果预览:
1.png

2.png

可以看到设计感潮流感十足,简洁大方,页面上有大量的留白区域和明暗背景交错,并有正常模式和方便夜间查看的暗黑模式。

资源导入

本案例为了简单起见,文字与颜色直接写在代码中,仅图片资源需要导入(见附件meida.zip),将全部所需图片拖到资源文件夹的media子目录中:

3.png

启动页结构

使用默认的index.ets入口页作为启动页,分析页面的结构,可以分为上下两个层:背景层、内容层。
内容层可分为导航、主题文字区、图片区。

页面整体的骨架结构代码可如下:

Stack {

Back()        <span class="hljs-comment"><span class="hljs-comment">//背景层</span></span>

Content() {  <span class="hljs-comment"><span class="hljs-comment">//内容层</span></span>
	
Nav()       <span class="hljs-comment"><span class="hljs-comment">//导航</span></span>

Theme()     <span class="hljs-comment"><span class="hljs-comment">//主题文字区</span></span>

Banner()    <span class="hljs-comment"><span class="hljs-comment">//图片区</span></span>

}	

} <button style="position: absolute; padding: 4px 8px 0px; cursor: pointer; top: 8px; right: 8px; font-size: 14px;">复制</button>

背景层

背景层效果看起来很不错,仔细观察设计,四个角都有镂空的图形做衬托。其中左上角是一朵花,其余三个角是呈辐射状的星星,最底层是一个有着渐变流动光影效果的图片。要创建组件,依照惯例,在pages目录下新建源码文件back.ets。

渐变流动光影

最底层是的图片特效非常独特,直接插入图片组件。

Stack() {

  Image($r(<span class="hljs-string"><span class="hljs-string">"app.media.bg"</span></span>))

}
.width(<span class="hljs-string"><span class="hljs-string">'100%'</span></span>)
.height(<span class="hljs-string"><span class="hljs-string">'100%'</span></span>)

<button style="position: absolute; padding: 4px 8px 0px; cursor: pointer; top: 8px; right: 8px; font-size: 14px;">复制</button>

在设备的正常模式与暗黑模式下有不同的渐变流动光影效果,从而使得用户对网站整体视觉上,似乎可以产生一股持续的如同文字主题想表达的,“溢彩生活”般的水波流动感。

4.png

5.png

图形衬边

页面四角有图形做衬托,首先是左上角的花枝:

Image($r(“app.media.leaf”))
.width(274)
.height(345)
<button style="position: absolute; padding: 4px 8px 0px; cursor: pointer; top: 8px; right: 8px; font-size: 14px;">复制</button>

6.png

首先让图形略微向右旋转倾斜:

Image($r(“app.media.leaf”))
.width(274)
.height(345)
.objectFit(ImageFit.Contain)
.rotate({
z: 1,
angle: 5}
)
<button style="position: absolute; padding: 4px 8px 0px; cursor: pointer; top: 8px; right: 8px; font-size: 14px;">复制</button>

7.png

然后将至包含在一个Row容器中以便默认左对齐,在包含在一个Column中以便居于上方,这样就让图形可以位于左上角。再适度让左偏移:

Column() {

    Row() {

      Image($r(<span class="hljs-string"><span class="hljs-string">"app.media.leaf"</span></span>))
        .width(<span class="hljs-number"><span class="hljs-number">274</span></span>)
        .height(<span class="hljs-number"><span class="hljs-number">345</span></span>)
        .objectFit(ImageFit.Contain)
        .rotate({
          z: <span class="hljs-number"><span class="hljs-number">1</span></span>,
          angle: <span class="hljs-number"><span class="hljs-number">5</span></span>}
        )
        .offset({
          x: -<span class="hljs-number"><span class="hljs-number">70</span></span>}
        )

    }
    .width(<span class="hljs-string"><span class="hljs-string">'100%'</span></span>)

    Blank()

  }
  .width(<span class="hljs-string"><span class="hljs-string">'100%'</span></span>)
  .height(<span class="hljs-string"><span class="hljs-string">'100%'</span></span>)

<button style="position: absolute; padding: 4px 8px 0px; cursor: pointer; top: 8px; right: 8px; font-size: 14px;">复制</button>

8.png

此时发现图片本身的色彩过于饱满,于是调整透明度为0.15:

Column() {

    Row() {

      Image($r(<span class="hljs-string"><span class="hljs-string">"app.media.leaf"</span></span>))
        .width(<span class="hljs-number"><span class="hljs-number">274</span></span>)
        .height(<span class="hljs-number"><span class="hljs-number">345</span></span>)
        .objectFit(ImageFit.Contain)
        .rotate({
          z: <span class="hljs-number"><span class="hljs-number">1</span></span>,
          angle: <span class="hljs-number"><span class="hljs-number">5</span></span>}
        )
        .offset({
          x: -<span class="hljs-number"><span class="hljs-number">70</span></span>}
        )

    }
    .width(<span class="hljs-string"><span class="hljs-string">'100%'</span></span>)

    Blank()

  }
  .width(<span class="hljs-string"><span class="hljs-string">'100%'</span></span>)
  .height(<span class="hljs-string"><span class="hljs-string">'100%'</span></span>)
  .opacity(<span class="hljs-number"><span class="hljs-number">0.15</span></span>)

<button style="position: absolute; padding: 4px 8px 0px; cursor: pointer; top: 8px; right: 8px; font-size: 14px;">复制</button>

9.png

如此一来,可以更好的融入背景色中。左下角的星形图片,参照做类似的处理:

 Column() {

    Blank()

    Row() {

      Image($r(<span class="hljs-string"><span class="hljs-string">"app.media.star_l"</span></span>))
        .width(<span class="hljs-number"><span class="hljs-number">358</span></span>)
        .height(<span class="hljs-number"><span class="hljs-number">358</span></span>)
        .objectFit(ImageFit.Contain)
        .offset({
          x: -<span class="hljs-number"><span class="hljs-number">40</span></span>}
        )

    }
    .width(<span class="hljs-string"><span class="hljs-string">'100%'</span></span>)

  }
  .width(<span class="hljs-string"><span class="hljs-string">'100%'</span></span>)
  .height(<span class="hljs-string"><span class="hljs-string">'100%'</span></span>)

<button style="position: absolute; padding: 4px 8px 0px; cursor: pointer; top: 8px; right: 8px; font-size: 14px;">复制</button>

10.png



关于HarmonyOS 鸿蒙Next版本实战 - 溢彩美妆App(1)的问题,您也可以访问:https://www.itying.com/category-93-b0.html 联系官网客服。


更多关于HarmonyOS 鸿蒙Next版本实战 - 溢彩美妆App(1)的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html

回到顶部