• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

鸿蒙学习笔记:长按事件八

武飞扬头像
✎﹏ℳ๓敬坤
帮助1

之前学习了单击事件,双击事件,今天继续实操一下长按事件。那长按事件有什么作用呢?

长按事件的使用场景有:复制,显示遮罩层等,都会用到长按。

接下就直接开始操作代码了,创建完项目,然后我们xml文件如下:

  1.  
    <?xml version="1.0" encoding="utf-8"?>
  2.  
    <DirectionalLayout
  3.  
    xmlns:ohos="http://schemas.huawei.com/res/ohos"
  4.  
    ohos:height="match_parent"
  5.  
    ohos:width="match_parent"
  6.  
    ohos:alignment="center"
  7.  
    ohos:orientation="vertical">
  8.  
     
  9.  
    <Text
  10.  
    ohos:id="$ id:text_helloworld"
  11.  
    ohos:height="match_content"
  12.  
    ohos:width="match_content"
  13.  
    ohos:background_element="$graphic:background_ability_main"
  14.  
    ohos:layout_alignment="horizontal_center"
  15.  
    ohos:text="长按事件页面"
  16.  
    ohos:text_size="40vp"
  17.  
    />
  18.  
    <Button
  19.  
    ohos:height="match_content"
  20.  
    ohos:width="match_content"
  21.  
    ohos:id="$ id:btn"
  22.  
    ohos:background_element="blue"
  23.  
    ohos:text_color="white"
  24.  
    ohos:text="长按按钮"/>
  25.  
    </DirectionalLayout>
学新通

接下来来写我们的长按事件:

Tips:

刚开始我们写长按事件时代码如下:

学新通

如上,我们发现这里并没有设置我们ui页面。

那如何快速生成ui页面呢,我们点击MainAbilitySlice然后Ctrl B就可以快速设置ui页面了,设置完ui页面如下:

学新通 这个时候ui页面就设置好了

 那我们如何写长按事件呢?

1.根据组件id找到我们的长按按钮

2.给长按按钮绑定长按事件

3.重写长按事件

具体代码如下:

  1.  
    package com.example.mydemolongclick.slice;
  2.  
     
  3.  
    import com.example.mydemolongclick.ResourceTable;
  4.  
    import ohos.aafwk.ability.AbilitySlice;
  5.  
    import ohos.aafwk.content.Intent;
  6.  
    import ohos.agp.components.Button;
  7.  
    import ohos.agp.components.Component;
  8.  
    import ohos.agp.components.Text;
  9.  
     
  10.  
    public class MainAbilitySlice extends AbilitySlice implements Component.LongClickedListener{
  11.  
    private Text txt;
  12.  
    @Override
  13.  
    public void onStart(Intent intent) {
  14.  
    super.onStart(intent);
  15.  
    super.setUIContent(ResourceTable.Layout_ability_main);
  16.  
    Button btn = (Button) findComponentById(ResourceTable.Id_btn);
  17.  
    txt=(Text) findComponentById(ResourceTable.Id_text_helloworld);
  18.  
    btn.setLongClickedListener(this);
  19.  
    }
  20.  
     
  21.  
    @Override
  22.  
    public void onActive() {
  23.  
    super.onActive();
  24.  
    }
  25.  
     
  26.  
    @Override
  27.  
    public void onForeground(Intent intent) {
  28.  
    super.onForeground(intent);
  29.  
    }
  30.  
     
  31.  
    @Override
  32.  
    public void onLongClicked(Component component) {
  33.  
    txt.setText("页面长按了");
  34.  
    }
  35.  
    }
学新通

当我们写完代码,具体效果如下:

长按前:学新通 长按后:学新通

 这样子我们就完成一个长按事件的实现!

==================分享不易,都观看到这里了,还不点赞收藏嘛!===================

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhibacaj
系列文章
更多 icon
同类精品
更多 icon
继续加载