鴻蒙系統(HarmonyOS)經典紅色風格登錄頁布局

預覽

簡介

基于鴻蒙系統(HarmonyOS)開發的現代化登錄界面,采用了科技感十足的紅色主題設計。該界面結合了流暢的動畫效果、精心設計的視覺元素和人性化的交互體驗,為用戶提供了一個安全、美觀且易用的登錄入口。

🎨 精美視覺設計

  • 科技感紅色主題:采用鮮明的紅色調作為主色調,搭配半透明背景和模糊效果,營造出強烈的視覺沖擊力
  • 精致的UI元素:包含精心設計的輸入框、按鈕、分割線和裝飾元素
  • 動態視覺效果:融入了細膩的動畫和過渡效果,提升用戶體驗

🛠? 實用功能

  • 用戶名/密碼登錄:支持傳統的賬號密碼登錄方式
  • 密碼可見性切換:用戶可以切換密碼的顯示/隱藏狀態
  • 短信驗證碼:集成了驗證碼獲取功能,包含60秒倒計時
  • 表單驗證:內置基礎的表單驗證邏輯,確保輸入完整性

🔄 交互體驗

  • 輸入框焦點動畫:當用戶聚焦于輸入框時,會觸發微妙的縮放動畫
  • 按鈕狀態反饋:按鈕會根據不同狀態展示不同的視覺效果
  • 友好的錯誤提示:使用對話框提供清晰的錯誤提示信息

技術亮點

  • 基于ArkTS語言:采用鴻蒙系統原生開發語言,性能優異
  • 聲明式UI:使用ArkUI框架的聲明式UI開發方式,代碼簡潔高效
  • 響應式設計:界面元素能夠適應不同尺寸的設備屏幕
  • 狀態管理:使用@State裝飾器管理組件狀態,實現UI與數據的同步
  • 動畫系統:利用鴻蒙系統的動畫API實現流暢的交互效果

使用場景

  • 移動應用的用戶登錄界面
  • 企業內部系統的身份驗證入口
  • 智能設備的用戶認證界面
  • 需要安全登錄的各類應用場景

源碼

@Entry
@Component
struct Index {@State username: string = ''@State password: string = ''@State verificationCode: string = ''@State countdown: number = 60@State isCounting: boolean = falseprivate intervalID: number = -1@State private rotateAngle: number = 0private rotateTimer: number = -1aboutToAppear() {// 啟動旋轉動畫this.rotateTimer = setInterval(() => {this.rotateAngle = (this.rotateAngle + 1) % 360}, 50)}aboutToDisappear() {// 清除定時器if (this.intervalID !== -1) {clearInterval(this.intervalID)}if (this.rotateTimer !== -1) {clearInterval(this.rotateTimer)}}// 開始倒計時startCountdown() {if (this.isCounting) {return}this.isCounting = truethis.countdown = 60this.intervalID = setInterval(() => {this.countdown--if (this.countdown <= 0) {this.isCounting = falseclearInterval(this.intervalID)}}, 1000)}// 模擬登錄login() {if (!this.username.trim()) {AlertDialog.show({title: '提示',message: '請輸入用戶名',confirm: {value: '確定',action: () => {console.info('用戶確認')}}})return}if (!this.password.trim()) {AlertDialog.show({title: '提示',message: '請輸入密碼',confirm: {value: '確定',action: () => {console.info('用戶確認')}}})return}if (!this.verificationCode.trim()) {AlertDialog.show({title: '提示',message: '請輸入驗證碼',confirm: {value: '確定',action: () => {console.info('用戶確認')}}})return}AlertDialog.show({title: '登錄成功',message: '歡迎回來,' + this.username,confirm: {value: '確定',action: () => {console.info('登錄成功')}}})}build() {Stack({ alignContent: Alignment.Center }) {// 背景Column().width('100%').height('100%').backgroundImage($r('app.media.background')).backgroundImageSize(ImageSize.Cover)// 半透明紅色遮罩層,增強視覺沖擊力Column().width('100%').height('100%').backgroundColor('rgba(180, 0, 0, 0.5)')// 登錄表單Column() {// 標題Row() {Text('登錄').fontSize(28).fontWeight(FontWeight.Bold).fontColor('#FFFFFF').textShadow({radius: 10,color: 'rgba(226, 35, 26, 0.8)',offsetX: 0,offsetY: 0})}.width('100%').justifyContent(FlexAlign.Center).margin({ bottom: 40 })// 用戶名輸入框Column() {Row() {TextInput({ placeholder: '請輸入用戶名', text: this.username }).placeholderColor('rgba(255, 255, 255, 0.6)').placeholderFont({ size: 16 }).caretColor('#E2231A').fontColor('#FFFFFF').backgroundColor('transparent').padding({ left: 0, right: 0 }).onChange((value) => {this.username = value}).width('85%').height(50)}.width('100%').padding({ left: 20, right: 20 })Divider().width('90%').height(1).color('rgba(226, 35, 26, 0.6)').margin({ top: 5 })}.margin({ bottom: 20 })// 密碼輸入框Column() {Row() {TextInput({ placeholder: '請輸入密碼', text: this.password }).placeholderColor('rgba(255, 255, 255, 0.6)').placeholderFont({ size: 16 }).caretColor('#E2231A').fontColor('#FFFFFF').backgroundColor('transparent').padding({ left: 0, right: 0 }).type(InputType.Password).onChange((value) => {this.password = value}).width('100%').height(50)}.width('100%').padding({ left: 20, right: 20 })Divider().width('90%').height(1).color('rgba(226, 35, 26, 0.6)').margin({ top: 5 })}.margin({ bottom: 20 })// 驗證碼輸入框Column() {Row() {TextInput({ placeholder: '請輸入驗證碼', text: this.verificationCode }).placeholderColor('rgba(255, 255, 255, 0.6)').placeholderFont({ size: 16 }).caretColor('#E2231A').fontColor('#FFFFFF').padding({ left: 0, right: 0 }).backgroundColor('transparent').type(InputType.Number).onChange((value) => {this.verificationCode = value}).width('55%').height(50)Button(this.isCounting ? `${this.countdown}秒后重試` : '獲取驗證碼').fontSize(14).fontWeight(FontWeight.Medium).fontColor(this.isCounting ? '#999999' : '#FFFFFF').backgroundColor(this.isCounting ? 'rgba(0, 0, 0, 0.3)' : 'rgba(226, 35, 26, 0.6)').width(120).height(40).borderRadius(20).enabled(!this.isCounting).onClick(() => {this.startCountdown()})}.width('100%').padding({ left: 20, right: 20 })Divider().width('90%').height(1).color('rgba(226, 35, 26, 0.6)').margin({ top: 5 })}.margin({ bottom: 40 })// 登錄按鈕Button('登 錄').width('90%').height(50).fontSize(18).fontWeight(FontWeight.Bold).borderRadius(25).backgroundColor('rgba(226, 35, 26, 0.6)').fontColor('#FFFFFF').onClick(() => {this.login()})}.width('90%').padding({top: 40,bottom: 40,left: 10,right: 10}).borderRadius(15).backgroundColor('rgba(40, 0, 0, 0.8)').backdropBlur(10).border({ width: 1, color: 'rgba(255, 50, 50, 0.5)' })}.width('100%').height('100%')}
}

?鴻蒙系統(HarmonyOS)經典紅色風格登錄頁布局 - 高質量源碼分享平臺-免費下載各類網站源碼與模板及前沿動態資訊

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/86268.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/86268.shtml
英文地址,請注明出處:http://en.pswp.cn/web/86268.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

C++虛函數多態

class C{ public:void x1(){};void x2(){};};C c; cout << sizeof(c) <<"\n";1字節 class D{ public:void x1(){};void x2(){};virtual void x3(){};//void *vptr看不見的虛函數表指針 }; D d; cout << sizeof(d) <<"\n";8字節類A…

新編輯器編寫指南--給自己的備忘

歡迎使用Markdown編輯器 你好&#xff01; 這是你第一次使用 Markdown編輯器 所展示的歡迎頁。如果你想學習如何使用Markdown編輯器, 可以仔細閱讀這篇文章&#xff0c;了解一下Markdown的基本語法知識。 新的改變 我們對Markdown編輯器進行了一些功能拓展與語法支持&#x…

目標檢測neck算法之MPCA和FSA的源碼實現

目標檢測neck算法之MPCA和FSA的源碼實現 使用BIBM2024 Spatial-Frequency Dual Domain Attention Network For Medical Image Segmentation的Frequency-Spatial Attention和Multi-scale Progressive Channel Attention改進neck. 接下來&#xff0c;我將講解它的源碼操作的實現…

MyBatis-Plus的3.5.7和PageHelper的那個版本對應

MyBatis-Plus的3.5.7和PageHelper的那個版本對應 根據你的知識庫中提到的信息&#xff1a; MyBatis-Plus 3.5.7 使用的是 JSqlParser 4.6 版本。PageHelper 若使用了不同版本的 JSqlParser&#xff08;如 4.7&#xff09;&#xff0c;會導致沖突。 ? 推薦對應關系 為了保證…

Apifox 6 月產品更新|支持 AI 能力、交互優化、在線文檔新增 SEO 設置、gRPC 項目支持前/后置操作

在 2025 年的 API 開發領域&#xff0c;Apifox 作為一款集 API 設計、調試、Mock 和測試于一體的協作平臺&#xff0c;已成為開發者的“得力助手”。然而&#xff0c;隨著業務需求的不斷增長&#xff0c;開發者對工具的效率和功能提出了更高的要求。6 月份&#xff0c;Apifox 推…

Acrobat JavaScript 從瀏覽器到 PDF 環境的轉換

目錄 什么是 JavaScript?JavaScript 核心語言與 Acrobat 特定 API學習 JavaScript 核心語言的挑戰瀏覽器與 Acrobat JavaScript 的關鍵差異在 Acrobat 中運行 JavaScript 代碼替代瀏覽器特定函數的方法后續學習建議什么是 JavaScript? JavaScript 最初于 1995 年作為 Netsca…

OpenCV CUDA模塊設備層-----指數運算函數exp()

操作系統&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 編程語言&#xff1a;C11 算法描述 OpenCV 的 CUDA 設備端數學函數 中的一個內聯函數&#xff0c;用于在 GPU 上對 uchar1 類型&#xff08;單通道圖像像素&#xff09;執行指數運算…

C++面向對象5——C++關鍵字、構造函數與拷貝構造函數

this關鍵字 C關鍵字this的深度解析 1. this指針的本質 在C中&#xff0c;this是一個特殊的隱式指針&#xff0c;它存在于每個非靜態成員函數內部&#xff0c;指向調用該函數的當前對象。其類型為&#xff1a; 對于非const成員函數&#xff1a;ClassName* const&#xff08;…

人工智能專業:探索未來的智慧前沿

親戚家的小孩剛高考完&#xff0c;問我人工智能專業是學什么、做什么的。趁機就寫一篇吧&#xff01; 人工智能專業&#xff1a;探索未來的智慧前沿 人工智能&#xff08;Artificial Intelligence&#xff0c;簡稱AI&#xff09;無疑是當今最熱門、最具顛覆性的技術之一。它正…

618風控戰升級,瑞數信息“動態安全+AI”利劍出鞘

每年的618電商促銷季&#xff0c;都是各大電商平臺和商家的兵家必爭之地。數以億計的消費者涌入線上平臺&#xff0c;期待已久的優惠券、秒殺商品如潮水般涌現&#xff0c;海量交易在瞬間達成&#xff0c;無疑是一場商業狂歡。 然而&#xff0c;在這場狂歡背后&#xff0c;自動…

神經網絡的架構

神經網絡中的基本術語 以上圖為例&#xff0c;相關的術語描述如下&#xff1a; 最左邊的稱為輸?層&#xff0c;其中的神經元稱為輸?神經元&#xff1b;最右邊的&#xff0c;即輸出層包含有輸出神經元&#xff1b;本例中的輸出神經元只有一個&#xff1b;中間層&#xff0c;既…

安全生產監測預警系統:構筑智能化的安全防線

安全生產監測預警系統是工業安全管理的核心工具&#xff0c;它利用物聯網、大數據、人工智能等技術&#xff0c;實現對生產環境、設備運行和人員行為的全方位監測&#xff0c;確保風險早發現、早預警、早處置。其核心功能涵蓋實時監測、智能預警、應急處置、數據分析與優化等多…

Java練習題精選6-10

Java練習題精選6-10 一、第六題二、第七題第八題第九題第十題 一、第六題 如何將兩個變量的值進行交換&#xff1f;假設變量a1&#xff0c;b2。 public class Main {public static void main(String[] args) {int a 1;int b 2;int tmp;System.out.println("交換前a&qu…

【GESP】C++四級考試大綱知識點梳理, (2) 結構體和二維數組

GESP C四級官方考試大綱中&#xff0c;共有11條考點&#xff0c;本文針對第2條考點進行分析介紹。 &#xff08;2&#xff09;掌握 C結構體、二維及多維數組的基本概念及使用 四級其他考點回顧&#xff1a; 【GESP】C四級考試大綱知識點梳理, (1) 指針 全文詳見&#xff1a;【G…

自動化測試--App自動化之項目實戰腳本編寫及封裝流程

1.App測試范圍 app自動化測試主要核心測試手機程序 測試方面&#xff1a; 功能測試 安裝卸載測試 升級測試 兼容性測試 網絡切換&#xff0c;中斷測試 橫豎屏切換 健壯性 2.測試環境的搭建 需要配置的環境 java jdk Java的環境 Android sdk 安卓環境 python環境…

【Unity】什么是前向渲染、延遲渲染、單通道渲染、多通道渲染?

好的&#xff0c;我們來深入剖析這些核心渲染概念&#xff0c;理解它們的原理、優缺點以及在Unity&#xff08;特別是URP&#xff09;中的應用。 核心概念&#xff1a;渲染路徑 (Rendering Path) 渲染路徑決定了光照和著色在場景中是如何計算和應用的。它定義了物體被繪制到屏…

OpenCV CUDA模塊設備層-----GPU上執行線程安全的 “原子取最大值” 操作函數

操作系統&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 編程語言&#xff1a;C11 算法描述 這是一個 OpenCV 的 CUDA 模塊&#xff08;cv::cudev&#xff09; 中封裝的原子操作函數&#xff0c;用于在 GPU 上執行線程安全的 “原子取最大…

【nRF52832】【環境搭建 1】【ubuntu下搭建nRF52832開發環境】

本文講述如何在 ubuntu 22.04 下開發 nRF52832. host 環境說明: $ uname -a Linux leo 6.8.0-60-generic #63~22.04.1-Ubuntu SMP PREEMPT_DYNAMIC Tue Apr 22 19:00:15 UTC 2 x86_64 x86_64 x86_64 GNU/Linux1. 安裝軟件 sudo apt install gcc-arm-none-eabisudo apt-get i…

【Nginx】403 Forbidden錯誤

當 Nginx 代理配置出現 403 Forbidden 錯誤時&#xff0c;通常是由于權限或配置問題導致。以下是常見原因和解決方案&#xff1a; 常見原因及解決方法 1. 后端服務器拒絕訪問 原因&#xff1a;后端 HTTPS 服務配置了 IP 白名單或訪問控制解決&#xff1a; 檢查后端服務器&…

詳解 `pip install -e .` 命令【PythonLinux】

詳解 pip install -e . 命令 pip install -e . 是 Python 開發中一個非常有用的命令&#xff0c;用于以"可編輯"或"開發"模式安裝當前目錄中的 Python 包。 命令分解 pip: Python 的包管理工具install: pip 的子命令&#xff0c;用于安裝包-e: 是 --edi…