Java之父詹姆斯·高斯林 (James Gosling)学鸿蒙(HarmonyOS),HarmonyOS(2)

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新HarmonyOS鸿蒙全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img

img
img
htt

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上鸿蒙开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip204888 (备注鸿蒙)
img

正文

image.png

3.2.2 Java代码创建Image

注释掉XML中配置的Image,我们改用Java代码实现。 在com.liziba.image.slice.MainAbilitySlice类的onStart方法中,创建Image代码如下:

package com.liziba.image.slice;

import com.liziba.image.ResourceTable;

import ohos.aafwk.ability.AbilitySlice;

import ohos.aafwk.content.Intent;

import ohos.agp.components.DirectionalLayout;

import ohos.agp.components.Image;

public class MainAbilitySlice extends AbilitySlice {

@Override

public void onStart(Intent intent) {

super.onStart(intent);

//创建一个Image组件

Image image = new Image(getContext());

image.setPixelMap(ResourceTable.Media_JamesGosling);

image.setHeight(500);

image.setWidth(500);

image.setScaleMode(Image.ScaleMode.STRETCH);

//创建一个布局

DirectionalLayout layout = new DirectionalLayout(getContext());

//Image组件添加到DirectionalLayout布局中

layout.addComponent(image);

super.setUIContent(layout);

}

@Override

public void onActive() {

super.onActive();

}

@Override

public void onForeground(Intent intent) {

super.onForeground(intent);

}

}

这里做了一个简单的缩放,将原图缩放到与Image大小一致,看下效果(嗯不错,长大了点,哈哈哈!!!):

image.png

3.3 属性

由于在实际开发中,XML配置UI的还是多一些,因为方便改动和统一管理,也更加灵活。所以属性这里,都用XML配置来演示啦!!! ​

3.3.1 透明度

设置透明度为0.2,透明度设置的越小,图片越透明,原图透明度为1。

ohos:alpha=“0.2”

<Image

ohos:id=“$+id:imageComponent”

ohos:height=“200vp”

ohos:width=“200vp”

ohos:image_src=“$media:JamesGosling”

ohos:alpha=“0.2”

/>

image.png

3.3.2 缩放系数

当我们给定的图片大小和Image组件设置的大小不一致的时候,我们往往需要通过缩放来实现兼容。(但是为了图片不失真,最后还是少用缩放,图片大小不符合尽量找美工做一张新的图片。) ​

缩放系数可设置X轴和Y轴方向两个参数,其实就是宽、高 ​

如下是缩放x和y轴都配置0.5的效果

ohos:scale_x=“0.5”

ohos:scale_y=“0.5”

<Image

ohos:id=“$+id:imageComponent”

ohos:height=“200vp”

ohos:width=“200vp”

ohos:image_src=“$media:JamesGosling”

ohos:scale_x=“0.5”

ohos:scale_y=“0.5”

/>

image.png

如下是配置为1的效果,默认为1,可以不配置:

ohos:scale_x=“1”

ohos:scale_y=“1”

<Image

ohos:id=“$+id:imageComponent”

ohos:height=“200vp”

ohos:width=“200vp”

ohos:image_src=“$media:JamesGosling”

ohos:scale_x=“1”

ohos:scale_y=“1”

/>

image.png

能不能配置为比1大的数呢?当然是可以的,这样会更加配置的缩放参数,进行放大。 比如配置一个2试试:

ohos:scale_x=“2”

ohos:scale_y=“2”

<Image

ohos:id=“$+id:imageComponent”

ohos:height=“200vp”

ohos:width=“200vp”

ohos:image_src=“$media:JamesGosling”

ohos:scale_x=“2”

ohos:scale_y=“2”

/>

image.png

3.3.3 裁剪

如果给定的图片太大了,超过了我们的Image设置的大小,那该怎么办呢? 这个时候我们可以使用裁剪,裁剪有下面这些参数,只演示一个吧!

| 属性名称 | 中文描述 | 取值 | 取值说明 | 使用案例 |

| — | — | — | — | — |

| clip_alignment | 图像裁剪对齐方式 | left | 表示按左对齐裁剪。 | ohos:clip_alignment=“left” |

| | | right | 表示按右对齐裁剪。 | ohos:clip_alignment=“right” |

| | | top | 表示按顶部对齐裁剪。 | ohos:clip_alignment=“top” |

| | | bottom | 表示按底部对齐裁剪。 | ohos:clip_alignment=“bottom” |

| | | center | 表示按居中对齐裁剪。 | ohos:clip_alignment=“center” |

我们先将Image组件设置小一点,这样我们能看出裁剪的效果,这里我们采取按左对齐裁剪:

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注鸿蒙)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

hos:clip_alignment=“center” |

我们先将Image组件设置小一点,这样我们能看出裁剪的效果,这里我们采取按左对齐裁剪:

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注鸿蒙)
[外链图片转存中…(img-g731ma9U-1713140365524)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 26
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值