Delphi分屏显示功能实现教程

实战派 ESP32-S3,双模无线开发板

ESP32-S3 原生支持 ESP-IDF,WiFi + 蓝牙一次搞定

本文还有配套的精品资源,点击获取 menu-r.4af5f7ec.gif

简介:分屏显示提高了工作时的效率,特别是在需要并行处理多个任务的场景中。Delphi作为一种强大的Windows开发工具,支持分屏显示功能的实现。本实例将指导开发者如何使用Delphi创建分屏显示的应用程序,并涉及多显示器支持的技术。我们将详细探讨使用TForm和TPanel组件进行分屏布局,以及如何响应用户的动态调整。此外,还会涉及到Windows API以管理多显示器和桌面扩展,以便开发者能够创建适应现代工作环境的应用程序。
分屏显示实例

1. 分屏显示的重要性和应用场景

在当今的IT工作中,分屏显示技术已经成为提高工作效率的重要工具之一。无论是程序员、设计师还是数据分析师,多任务处理已成为一种常态。通过合理地配置屏幕空间,可以同时展示多个窗口,从而实现快速的信息对比和协作。

1.1 分屏显示的重要性

分屏显示技术能够使用户在不增加物理屏幕的情况下,通过软件模拟扩展桌面空间。这种技术大幅降低了多屏幕设置的成本,同时也提高了工作效率。分屏模式减少了鼠标和键盘在不同应用程序间的切换频率,有助于保持工作流的连贯性。

1.2 分屏显示的应用场景

分屏显示技术广泛应用于多种场景,如:

  • 编程开发 :在编码的同时预览应用程序输出结果。
  • 数据分析 :在进行数据处理时,实时查看数据源和分析工具。
  • 设计制图 :同时查看设计规范和绘图界面,确保设计的一致性。
  • 视频编辑 :将时间线、素材库和预览窗口一起展示,提高编辑效率。

在这一章中,我们将深入探讨分屏显示技术的背景知识、实现方法和应用策略,旨在为IT专业人士提供一套完整的分屏显示解决方案。

2. Delphi中分屏显示的实现方法

Delphi作为一款强大的快速应用程序开发工具,为开发者提供了创建分屏显示功能的多种途径和丰富的组件库。在本章节,我们将深入了解Delphi中分屏显示的实现方法,包括窗体设计基础、分屏显示的基本技术原理以及利用Windows API进行多显示器管理的应用。

2.1 Delphi的窗体设计基础

Delphi中的窗体是应用程序用户界面的核心,理解窗体的概念和窗体与子窗体的关系对于设计复杂的分屏布局至关重要。

2.1.1 理解Delphi的窗体概念

在Delphi中,窗体(Form)是可视化组件的容器,用于构建应用程序的用户界面。每个窗体都可以包含按钮、文本框、面板等控件。窗体本身也可以嵌套,形成子窗体(SubForm),这样可以创建复杂的多层界面布局。理解窗体的这些基本概念对于后续深入掌握分屏显示的设计至关重要。

2.1.2 窗体与子窗体的关系

在Delphi中,子窗体是作为父窗体的一部分存在的。通常情况下,子窗体用于封装一组具有相似功能的界面元素,比如一个用户信息编辑界面可以作为主窗体的子窗体。通过使用子窗体,开发者可以将复杂的应用程序分解为更小的、更易于管理的单元,同时保持代码的清晰和结构化。要正确使用子窗体,开发者需要熟悉如何在设计时添加、配置以及在运行时显示和隐藏子窗体。

2.2 分屏显示的基本技术原理

分屏显示的实现依赖于窗体设计和界面元素的管理。接下来,我们将探讨分屏显示的具体技术原理,包括算法实现和Delphi中分屏显示相关API的概览。

2.2.1 分屏显示的算法实现

分屏显示算法的实现通常涉及到窗体或面板控件的位置和大小调整。在Delphi中,可以通过编程控制这些控件的位置属性(Left, Top, Width, Height)以及Z-order(即窗体或控件在显示层叠中的顺序)来创建分屏效果。算法的核心是确定如何响应用户操作(如拖拽分隔条)来重新计算并更新界面布局。

2.2.2 Delphi中分屏显示的API概览

Delphi提供了丰富的API来支持分屏显示,例如 TForm 类中的 Width , Height , Top , Left 属性,以及 Align 属性等。此外, TControl 类的 Move 方法, TForm SetBounds 方法等都是管理窗体布局的关键API。开发者可以通过这些API来动态地调整窗体和控件的布局,以实现分屏功能。在实际的分屏实现中,还需要关注如何保存和恢复用户设置的布局,以便在应用程序重启后,用户可以恢复之前的布局状态。

在下一章,我们将进一步探讨如何使用TForm和TPanel创建分屏布局,以及如何动态调整和管理分屏。我们将展示代码实现的详细步骤,并讨论实际应用场景中的优化策略。

3. 使用TForm和TPanel创建分屏布局

在现代应用程序开发中,用户界面(UI)的设计往往需要具有高度的互动性和直观性。分屏布局作为一种流行的UI设计模式,能够在同一个应用程序窗口内创建出多个独立的显示区域,使得用户能够同时处理多个任务。Delphi,作为一种高效的应用程序开发工具,提供了强大的组件和对象导向设计模式,使得开发者可以轻松实现分屏布局。

3.1 设计多面板的用户界面

3.1.1 面板控件的属性和事件

TPanel是一个广泛应用于Delphi应用程序中的控件,它可以用来创建一个或多个分割区域,每个区域可以承载其他控件,如按钮、文本框等。在创建分屏布局时,TPanel扮演了至关重要的角色。通过设置面板控件的属性,可以控制面板的外观和行为。例如:

  • Align 属性可以定义面板相对于其父窗体的位置,常用的选项包括 alTop , alBottom , alLeft , alRight 等。
  • BevelInner BevelOuter 属性用来给面板添加内嵌和外嵌边框,让面板更加突出和具有立体感。
  • BorderWidth 属性可以设定面板边框的宽度,增加视觉效果和用户体验。
  • Brush 属性用来设置面板的背景颜色或图案。

同时,面板控件可以响应各种事件,如 OnClick OnResize 等。这些事件可以用来实现各种用户交互逻辑,比如点击面板时执行某个动作,或者当面板大小改变时重新排列内部控件。

3.1.2 分屏布局的实现步骤

实现分屏布局的步骤通常涉及以下几个关键阶段:

  1. 设计窗体布局,在设计视图中放置必要的TPanel控件,并将它们放置到希望的位置。
  2. 设置TPanel的 Align 属性,确定面板相对于窗体的位置。
  3. 调整TPanel的 Width Height 属性,以适应分屏的大小。
  4. 在每个TPanel内部继续放置所需的控件,如标签、按钮等,并适当调整它们的大小和位置。
  5. 为每个控件编写事件处理逻辑,以响应用户的交互操作。

在实际开发中,还可能需要根据应用程序的特定需求,调整面板的属性或事件处理逻辑。

// 示例:创建一个简单分屏布局的Delphi代码

procedure TForm1.FormCreate(Sender: TObject);
var
  Panel1: TPanel;
  Panel2: TPanel;
begin
  // 创建并设置第一个面板
  Panel1 := TPanel.Create(Self);
  Panel1.Parent := Self;
  Panel1.Align := alLeft;
  Panel1.Width := 200;
  Panel1.Height := 400;
  // 创建并设置第二个面板
  Panel2 := TPanel.Create(Self);
  Panel2.Parent := Self;
  Panel2.Align := alClient;
  Panel2.BevelInner := bvNone;
  Panel2.BevelOuter := bvLowered;
  // 在第一个面板中添加一个按钮作为示例
  Button1 := TButton.Create(Panel1);
  Button1.Parent := Panel1;
  Button1.Caption := '左侧分屏';
  Button1.Width := Panel1.Width;
  Button1.Height := 50;
end;

3.2 动态调整和管理分屏

3.2.1 界面的动态响应技术

在分屏应用中,动态调整是提升用户体验的关键。开发者需要考虑到屏幕尺寸变化、面板大小调整以及控件重排等场景。动态响应技术可以通过响应特定的事件,如窗口的 OnResize 事件来实现。

OnResize 事件处理程序中,可以编写逻辑来重新计算和调整面板的位置和大小,以适应新的窗口尺寸。

procedure TForm1.FormResize(Sender: TObject);
begin
  // 示例:根据窗体大小变化,动态调整面板位置和大小
  if Width > Height then
  begin
    Panel1.Width := Width div 2;
    Panel1.Height := Height;
    Panel1.Left := 0;
    Panel1.Top := 0;
    Panel2.Left := Panel1.Width;
    Panel2.Top := 0;
    Panel2.Width := Width - Panel1.Width;
    Panel2.Height := Height;
  end
  else
  begin
    // 根据实际情况进行其他屏幕方向的布局调整
    // ...
  end;
end;

3.2.2 分屏界面的优化策略

在多屏应用中,优化策略的实施对于提供流畅和高效的用户体验至关重要。以下是一些常见的优化策略:

  • 资源管理: 确保在添加新控件或动态修改面板内容时,及时释放不再使用的资源,避免内存泄漏。
  • 性能监控: 监控应用程序在不同屏幕分辨率和不同数量的屏幕下的运行性能,尤其是在执行重绘和数据处理操作时。
  • 用户交互: 确保用户能够轻松地在屏幕之间切换和控制分屏布局,提供清晰的视觉和触觉反馈。
  • 布局持久化: 当应用程序关闭并重新打开时,应能够保持用户之前的分屏设置,例如屏幕大小和位置。

通过这些优化策略,开发者可以确保分屏应用能够适应不同的用户需求和硬件环境,同时提供稳定和一致的用户体验。

// 示例:资源管理策略的Delphi代码

procedure TForm1.FreeUnusedResources;
begin
  // 示例:释放不需要的资源
  if Assigned(OldComponent) then
  begin
    OldComponent.Free;
    OldComponent := nil;
  end;
  // 其他资源清理逻辑...
end;

请注意,以上内容仅为第三章的一部分内容。根据您的要求,下一章节将详细展开第四章“Windows API在多显示器管理中的应用”的内容。

4. Windows API在多显示器管理中的应用

在现代计算环境中,使用多显示器已经成为日常工作的一部分。它使得工作空间更宽裕,提高了生产力和多任务处理的能力。程序员和系统管理员都需要管理这些多显示器环境,确保窗口和应用程序正确地在多个屏幕上放置和显示。本章节将深入探讨Windows API在管理多显示器环境中的应用,探索如何利用Windows提供的API来创建跨屏幕的应用程序。

4.1 探索Windows多显示器支持

Windows操作系统提供了强大的API来支持多显示器环境。开发人员可以利用这些API来获取显示器信息,移动窗口到不同的显示器上,以及处理多显示器特有的事件。

4.1.1 多显示器环境下的API

在多显示器的环境中,系统会将每个显示器视为一个独立的桌面,应用程序可以在这个桌面空间中创建和移动窗口。为了编程实现这些功能,我们需要熟悉几个关键的API函数:

  • EnumDisplayMonitors :这个函数可以枚举所有的显示器,并对每个显示器执行一个回调函数。
  • GetMonitorInfo :这个函数可以获取特定显示器的信息,如显示器的工作区域、显示器的边界等。
  • MonitorFromWindow :这个函数可以获取包含特定窗口的显示器的句柄。
  • SetWindowPos :这个函数允许我们将窗口移动到不同的显示器上。

4.1.2 窗口在多显示器间的移动

在多显示器环境中,让窗口在不同显示器之间移动是一项基本的需求。以下是一个简单的例子,演示如何使用 SetWindowPos 函数来移动窗口:

procedure MoveWindowToMonitor(windowHandle: HWND; monitorIndex: Integer);
var
  MonitorInfo: TMonitorInfo;
  MonitorArray: array of HMONITOR;
  MonitorCount: DWORD;
  Monitor: HMONITOR;
  WorkArea: TRect;
begin
  // 获取当前系统有多少个显示器
  MonitorCount := GetSystemMetrics(SM_CMONITORS);
  SetLength(MonitorArray, MonitorCount);

  // 枚举所有显示器
  if EnumDisplayMonitors(0, nil, @EnumMonitorsCallback, NativeInt(@MonitorArray)) then
  begin
    // 获取目标显示器的信息
    Monitor := MonitorArray[monitorIndex];
    GetMonitorInfo(Monitor, MonitorInfo);
    // 获取显示器的可用工作区域
    WorkArea := MonitorInfo.rcMonitor;
    Inc(WorkArea.Left, MonitorInfo.rcWork.Left);
    Inc(WorkArea.Top, MonitorInfo.rcWork.Top);
    Dec(WorkArea.Right, MonitorInfo.rcWork.Right - MonitorInfo.rcMonitor.Right);
    Dec(WorkArea.Bottom, MonitorInfo.rcWork.Bottom - MonitorInfo.rcMonitor.Bottom);
    // 移动窗口到指定显示器的可用工作区域
    SetWindowPos(windowHandle, HWND_TOP, WorkArea.Left, WorkArea.Top, WorkArea.Right - WorkArea.Left, WorkArea.Bottom - WorkArea.Top, SWP_SHOWWINDOW);
  end;
end;

function EnumMonitorsCallback(Monitor: HMONITOR; DC: HDC; Rect: PRect; Data: LPARAM): Boolean; stdcall;
var
  MonitorArray: array of HMONITOR;
  MonitorCount: PDWORD;
begin
  MonitorCount := PPointer(Data)^;
  SetLength(MonitorArray, MonitorCount^);
  MonitorCount^ := MonitorCount^ + 1;
  MonitorArray[MonitorCount^ - 1] := Monitor;
  Result := True;
end;

在这个代码示例中, MoveWindowToMonitor 函数接受一个窗口句柄和一个显示器索引,然后将窗口移动到指定的显示器上。 EnumMonitorsCallback 是一个枚举回调函数,用于收集所有显示器的句柄。

4.2 跨屏幕应用程序窗口放置

为了提供良好的用户体验,应用程序窗口在多显示器设置中应该能够智能地放置和管理。开发人员需要了解如何利用Windows API来优化窗口放置策略。

4.2.1 窗口位置管理的API调用

为了有效地管理窗口位置,我们需要使用 SetWindowPos 函数来改变窗口的位置和大小。同时,我们也可以使用 GetWindowRect MoveWindow 等函数来获取和设置窗口的位置信息。

4.2.2 窗口放置策略和用户体验

在多显示器环境下,窗口放置策略对于用户体验至关重要。以下是一些可能的策略:

  • 默认位置 :为应用程序窗口分配一个默认位置,比如主显示器的左上角。
  • 上次位置 :记录并恢复用户上次关闭窗口时的位置。
  • 空间最大化 :自动将窗口放置在当前有最多可用空间的显示器上。
  • 用户配置 :允许用户手动选择窗口的放置位置。

下表展示了不同策略的潜在优缺点:

放置策略 优点 缺点
默认位置 简单易行,用户无需操作 可能不适应用户的使用习惯
上次位置 尊重用户的个人设置 用户可能在多个显示器间切换工作
空间最大化 灵活,充分利用可用空间 用户可能觉得窗口移动了,感到不习惯
用户配置 完全自定义,满足个性化需求 需要用户进行额外的配置步骤

mermaid流程图可以用于可视化这些策略的决策过程:

graph TD
    A[开始] --> B{选择放置策略}
    B -->|默认位置| C[将窗口放置在默认位置]
    B -->|上次位置| D[查找并使用用户上次关闭窗口的位置]
    B -->|空间最大化| E[将窗口放置在有最多可用空间的显示器]
    B -->|用户配置| F[询问用户放置窗口的位置]
    C --> G[完成窗口放置]
    D --> G
    E --> G
    F --> G

在实际开发中,开发人员需要根据应用程序的用途和用户的需求来选择合适的窗口放置策略。例如,对于全屏应用程序来说,可能会倾向于“空间最大化”策略,而对于需要对比的双屏应用程序,可能需要采用“用户配置”策略以允许用户将两个窗口并排放置。

在本章中,我们探索了Windows API在多显示器支持方面的能力,介绍了如何通过API实现窗口在不同显示器之间的移动。此外,我们还讨论了跨屏幕应用程序的窗口放置策略,并提供了一些可供选择的策略以及它们的优缺点。这些知识将为开发多显示器环境下高效的应用程序提供坚实的基础。在下一章中,我们将深入探讨Delphi组件和API在分屏及多屏应用中的运用,展示如何将这些技术应用于具体案例中。

5. Delphi组件和API在分屏及多屏应用中的运用

5.1 Delphi组件在分屏功能中的作用

Delphi是一个功能丰富的集成开发环境(IDE),它为分屏功能提供了多个组件,这些组件使得开发者能够更高效地创建分屏界面。在这一节中,我们将深入了解几个关键组件的作用及其在分屏应用中的应用方式。

5.1.1 核心组件的介绍与应用

在Delphi中,核心组件如 TForm , TPanel , TSplitter 等,是实现分屏功能的关键。每个组件都承载着特定的职责和功能。

  • TForm 作为应用程序的主窗体,承担着容器的角色,它可以容纳其他组件,例如 TPanel TSplitter
  • TPanel 提供了空间来组织其他控件,并可以设置不同的边框样式以区分不同的分屏区域。
  • TSplitter 允许用户通过拖动来调整相邻控件的大小,这对于动态分屏界面尤其重要。

这些组件通过属性和事件,使得我们可以根据需要进行布局设计和用户交互的定制。

5.1.2 组件的高级定制和扩展

Delphi允许开发者通过继承已有的组件类来创建自定义的分屏组件。高级定制可能包括改变组件的外观、行为,或者添加新的属性和事件处理程序以适应特定的业务需求。

例如,我们可以创建一个继承自 TSplitter 的新组件 TCustomSplitter ,为它添加一个属性来存储分隔条的位置信息,并在移动分隔条时触发自定义事件,以实现更加复杂的用户交互逻辑。

5.2 分屏及多屏应用的实战演练

在这一部分,我们将通过实际案例分析和代码实现,展示如何运用Delphi组件和API来开发分屏及多屏应用程序。

5.2.1 实际案例分析

假设我们需要设计一个应用程序,它需要在一块主屏幕上显示实时数据,在另一块屏幕上显示图表分析。我们将如何使用Delphi组件和API来实现这个需求?

首先,我们会在主窗体上放置两个 TPanel 组件,并将它们放置在 TForm 的左右两侧。然后,我们添加一个 TSplitter 组件来允许用户根据需要调整这两个面板的大小。

5.2.2 代码实现与问题解决

在设计完界面后,我们编写代码来实现功能。以下是一个简单的示例代码,展示了如何初始化分屏,并处理分屏的动态调整:

procedure TForm1.FormCreate(Sender: TObject);
begin
  // 初始化分屏控件
  Panel1.Caption := '实时数据';
  Panel2.Caption := '图表分析';
end;

procedure TForm1.Splitter1MouseDown(Sender: TObject; Button: TMouseButton;
  Shift: TShiftState; X, Y: Integer);
begin
  // 用户按下鼠标时调整分屏位置
  Splitter1.Cursor := crHSplit;
end;

procedure TForm1.Splitter1MouseMove(Sender: TObject; Shift: TShiftState;
  X, Y: Integer);
begin
  // 用户移动鼠标时调整分屏位置
  Splitter1.Cursor := crHSplit;
end;

procedure TForm1.Splitter1MouseUp(Sender: TObject; Button: TMouseButton;
  Shift: TShiftState; X, Y: Integer);
begin
  // 用户释放鼠标时重置光标
  Splitter1.Cursor := crDefault;
end;

在此代码中,我们处理了 TSplitter MouseDown , MouseMove MouseUp 事件,以便在用户与分隔条交互时提供即时反馈。在实际应用中,我们可能还需要添加更多的逻辑来处理窗口的最小化、最大化和关闭等情况,以及优化分屏布局以适应不同的屏幕分辨率。

通过上述方法,我们展示了如何在Delphi中使用核心组件和事件处理来创建一个实用的分屏应用程序。这种类型的布局在金融分析、程序开发和内容创作等多种场景中非常有用,可以帮助用户高效地处理和查看大量信息。

在下一节中,我们将继续探讨如何利用Windows API进一步优化多显示器的支持和管理。

本文还有配套的精品资源,点击获取 menu-r.4af5f7ec.gif

简介:分屏显示提高了工作时的效率,特别是在需要并行处理多个任务的场景中。Delphi作为一种强大的Windows开发工具,支持分屏显示功能的实现。本实例将指导开发者如何使用Delphi创建分屏显示的应用程序,并涉及多显示器支持的技术。我们将详细探讨使用TForm和TPanel组件进行分屏布局,以及如何响应用户的动态调整。此外,还会涉及到Windows API以管理多显示器和桌面扩展,以便开发者能够创建适应现代工作环境的应用程序。


本文还有配套的精品资源,点击获取
menu-r.4af5f7ec.gif

实战派 ESP32-S3,双模无线开发板

ESP32-S3 原生支持 ESP-IDF,WiFi + 蓝牙一次搞定

一些老的控件的集合: ------------------------------------------------------------------ xtoolbar.zip 41K 作者: Jean-Philippe Bernardy. 很不错的工具条控件 armenutb.zip 33K 作者: Albert Research。 提供用TListView选择全部的 Menu Item的工具条控件 dfssatausbar.zip 36K 作者: Brad Stowers。 TDFSStatusBar 是加强版 TStatusBar 构件,能够在其内放置其他构件(可在IDE环境瞎直接拖放),提供显示键盘上( CAPS Lock、NUM Lock、SCROLL Lock) 的状态,并提供进度显示进度及当前时间日期等多项功能 dfstoolbar.zip 10K 作者: Brad Stowers。 TDFSToolBar 是增强型的 TToolBar 构件,提供类似 Netscape Communicator 般的工具条,能够放到最大化及还原 sfoutbar.zip 23K 作者: Sylvain Frere. 类似Microsoft Outlook控制条控件,功能有支持大小图标显示,平滑滚动,快捷键,多重选择等 tbargood.zip 44K 作者: Seth Taylor。 配置 TForm TiTle的控件,功能很多 colorbtn.zip 9K Windows95风格的选择颜色的按钮元件 bcolorbtn.zip 26K 作者: Brad Stowers. Windows95风格的选择颜色的按钮元件 explbtn.zip 37K 作者: Fabrice Deville 。 TExploreButton 是类似 Microsoft Internet Explorer 3.0 式样的 Speed Button gradbutt.zip 13K 作者: Harm TGradBtn 是能够显示渐变颜色的 TButton 构件,并能控制按钮上文字以多种立体样式显示 avhebchk.zip 13K 作者: Alex Zanis. 在右边显示选择勾的CHeckBox控件,适合从右到作的语言如阿拉伯语. amcbrb.zip 10K 作者: Alexander Meeder。 以BMP图片自定义显示外观的增强型 TRadioButton 及 TCheckBox 构件 noshape.zip 86K 作者: Michael Tran 能够照指定的BMP 图像外观直接变成按钮外观的增强型按钮构件,带Exe演示程序 hnoshape.zip 4K 能够照指定两个BMP 图像变成按钮外观的增强型按钮构件 btchkbox.zip 5K 增强型TCheckBox 构件,可以按不同的选取状态选择各自BMP图片 jcheck10.zip 12K 很漂亮的增强型TCheckBox 构件 lightchk.zip 2K 作者: Frederic Vanmol。 圆形 LED 类型的 TCheckBox 构件,可以加亮变暗. speedrol.zip 1K 可以根据Button不同状态(Up,Down,Over)显示不同图片,支持一个大Glyph分成三个按钮图. transrad.zip 2K 作者: Jason Looney. 透明Ridio Button torrybtn.zip 81K 作者: Maxim Peresada, Rob Schoenaker. TTorryButton 是增强型的 TSpeedButton 构件,外观如同一个普通的 TLabel 般,当鼠标移动至按钮上方,立即显示出按钮边框及加亮的LED 类型.带Exe演示程序 jcheck10.zip 12K 作者: Jan Hulala。 Windows98 外观的增强型 TCheckBox 构件. coolbtn.zip 2K 作者: Geert Vos。 TCoolButton2 是增强型的 TSpeedButton 构件,当鼠标移至其上方时按钮上的文字将会出现阴影 corelbtn.zip 2K 作者: Peter Theill。 提供类似 Corel 公司产品( Corel Photo Paint )中的特殊样式按钮 mscheckb.zip 5K 作者: Vasily Kholopov. 增强型的 TBitBtn 构件,当被鼠标按下时能够改变 Glyphs 格式 .BMP 的显示内容 shakebtn.zip 36K 作者: Harm. Sh
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值