Scratch3.0 二次开发(2)改个Logo

2024-02-29 06:18

本文主要是介绍Scratch3.0 二次开发(2)改个Logo,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • Hello World
  • 想要的效果
  • 先看下源代
  • 最最粗爆的方法
  • 更和谐的方法

Hello World

简单换个Logo就跟Hello world一样一样的。实现这个就能基本掌握这个代码的来龙去脉。

想要的效果

如下图:
在这里插入图片描述
先准备好一张Logo图片(比较推荐透明背景的svg或png),下面这是我的
在这里插入图片描述

先看下源代

源码结构如下图:
在这里插入图片描述
换Logo这种事,显然就是UI的事了,所以定位到components目录下。
logo位于菜单栏,我们看下menu-bar.jsx文件。大约330行的位置:
在这里插入图片描述
Logo 源自属性:this.props.logo,这个属性的值是什么呢?它可以是上层传入的,不过在menu-bar.jsx中也指定了一个默认值,如下:
在这里插入图片描述
scratchLogo就是图片的资源文件,大约在73行的位置import的:
在这里插入图片描述
OK,找到位置要改就简单了。

最最粗爆的方法

把我们的Logo图片文件也复制到这个目录下,修改下import的资源文件名,如下图:
在这里插入图片描述
如果,你的项目正在运行的状态,回到浏览器,你就可以看到效果了。

更和谐的方法

在做二次开发时,还是比较建议把我们改的尽可能的集中在一块,东改一点西改一点,后续维护也不方便。
即然,this.props.logo是外界传入的属性值,更好的方法应该就是在更外层的某个地方来改。比如,可以在 playground 的 render-gui.jsx 里修改。
如下图:
在这里插入图片描述
效果跟前成的方法一样一样的。
眼尖的你应该已经注意到,在12行和84行有一个onClickLogo属性,这个属性指定点击Logo的行为,默认是跳到scratch官网,自行修改吧。

今天就先到这吧,拜~

这篇关于Scratch3.0 二次开发(2)改个Logo的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/757825

相关文章

Superset二次开发之Select 筛选器源码分析

路径:superset-frontend/src/filters/components/Select  源码文件: 功能点: 作用 交互 功能 index.ts作为模块的入口点,导出其他文件中定义的主要组件和函数。它使其他文件中的导出可以被外部模块使用。 SelectFilterPlugin.tsx 定义主要的插件类 SelectFilterPlugin 和组件 Sele

了解elementUI的底层源码, 进行二次开发

Element UI 是一个基于 Vue.js 的桌面端组件库,广泛用于构建美观、交互友好的用户界面。要深入理解 Element UI 的底层源码并进行二次开发,你需要掌握以下几个关键点: Vue.js 原理 Element UI 是基于 Vue.js 构建的,因此首先需要熟悉 Vue.js 的核心概念和机制,包括: ● 组件系统:Vue.js 的组件化思想,如何定义组件、使用组件、传递属性和事

关于武汉高芯coin417G2红外机芯的二次开发

文章目录 前言一、外观和机芯参数二、SDK的使用1、打开相机2、回调函数中获取全局温度和图像3、关闭相机 前言 最近工作中接触了一款基于武汉高芯科技有限公司开发的红外模组,即coin417g2(测温型)+9.1mm镜头.使用此模组,开发了一套红外热成像检测桌面应用程序.下面简单记录下该模组的使用. 一、外观和机芯参数 如下是该机芯的外观和机芯参数: 二、SDK

NX二次开发—进阶(二)

一、创建圆弧 在NX上通过代码画出圆弧,定义起始和终止位置,还有圆心位置和半径 创建圆弧,需要获取CSYS的矩阵ID,通过UF_CURVE_create_arc函数进行创建 //定义参数UF_CURVE_arc_t arc;arc.start_angle = 0.0;arc.end_angle = 225 * DEGRA;//DEGRA=PI/180//中心坐标arc.arc_center

NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001

由于需要对NFI进行汉化,以及二次开发,首先要下载源码以后编辑通过,NIFI的源码,项目非常多,编译过程中需要编译超过570个jar包,同时编译过程很慢需要30多分钟. 1.首先下载NIFI源码,根据需要下载对应版本: https://github.com/kemixkoo/orchsym-runtime/   首先介绍一下,这个是一个公司根据nifi进行定制开发的,已经汉化,但是不能商

NX二次开发——进阶(一)

一、链表及相关函数的用法 函数说明UF_MODL_create_list创建一个链表,并返回链表的头指针UF_MODL_put_list_item插入元素到链表中,不检验对象是否重复,或者已经存在UF_MODL_ask_list_count获取链表对象数量,从头开始遇到null_tag结束UF_MODL_ask_list_item查询链表对象标识,给个位置返回标识UF_MODL_delete_l

​​NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南002

继续,执行pom.xml引入依赖以后,发现以下几种报错: 可以看到在下载aws-java-sdk-bundle 1.12.710版本的时候报错了 可以看到日志信息,就是在阿里云上下载的,因为阿里云上缺少这个jar包 aws-java-sdk-bundle-1.12.710.jar 这个jar包,我还特意去阿里云上查询了一下 https://developer.aliyun.com/

恋爱相亲交友系统源码原生源码可二次开发APP 小程序 H5,web全适配

直播互动:平台设有专门的直播间,允许房间主人与其他异性用户通过视频连线的方式进行一对一互动。语音视频交流:异性用户可以发起语音或视频通话,以增进了解和交流。群组聊天:用户能够创建群聊,邀请自己关注的异性朋友加入,以便进行多人在线交流。虚拟礼品赠送:平台提供多样化的虚拟礼物,不同礼物有不同的价值,用户可以用来表达好感或支持。私人消息:异性用户之间可以互相发送私人信息,不过平台为了维护用户体验,对

UG二次开发CreateDialog函数在UI.hxx文件和WinUser.h中的冲突

文章出自https://blog.csdn.net/qq_41843732/article/details/91422764 在UG二次开发中,若使用MFC库,一旦加上#include<Afx.h>头文件,下面这句话就报错 theDialog = GetPoints::theUI->CreateDialog(theDlxFileName); 解决CreateDialog函数在UI.hx

基于Python、Tkinter制作带logo的二维码

一、离线安装python环境 下载4个纯净的虚拟环境:base-env-py36、base-env-py37、base-env-py38、base-env-py39。 对应的python版本分别是python3.6、python3.7、python3.8、python3.9。解压放到envs目录下: 打开Anaconda Prompt,查看现有的环境: 基于纯净的虚拟环境base