This commit is contained in:
zhuzihcu 2023-03-06 18:08:01 +08:00
parent 1ad1aa058a
commit d9ed37d3af
23 changed files with 588 additions and 729 deletions

View File

@ -21,9 +21,6 @@ FluWindow {
showFps: true showFps: true
} }
Item{
id:data
ListModel{ ListModel{
id:nav_items id:nav_items
ListElement{ ListElement{
@ -46,6 +43,10 @@ FluWindow {
text:"InfoBar" text:"InfoBar"
page:"qrc:/T_InfoBar.qml" page:"qrc:/T_InfoBar.qml"
} }
ListElement{
text:"Dialog"
page:"qrc:/T_Dialog.qml"
}
ListElement{ ListElement{
text:"Progress" text:"Progress"
page:"qrc:/T_Progress.qml" page:"qrc:/T_Progress.qml"
@ -67,7 +68,6 @@ FluWindow {
page:"qrc:/T_Typography.qml" page:"qrc:/T_Typography.qml"
} }
} }
}
FluIconButton{ FluIconButton{
icon:FluentIcons.FA_navicon icon:FluentIcons.FA_navicon
@ -123,25 +123,6 @@ FluWindow {
Rectangle{ Rectangle{
color: {
if(FluTheme.isDark){
if(item_mouse.containsMouse){
return "#292929"
}
if(nav_list.currentIndex === index){
return "#2D2D2D"
}
return "#00000000"
}else{
if(item_mouse.containsMouse){
return "#EDEDED"
}
if(nav_list.currentIndex === index){
return "#EAEAEA"
}
return "#00000000"
}
}
radius: 4 radius: 4
anchors{ anchors{
top: parent.top top: parent.top
@ -153,8 +134,6 @@ FluWindow {
leftMargin: 6 leftMargin: 6
rightMargin: 6 rightMargin: 6
} }
MouseArea{ MouseArea{
id:item_mouse id:item_mouse
hoverEnabled: true hoverEnabled: true
@ -163,6 +142,25 @@ FluWindow {
nav_list.currentIndex = index nav_list.currentIndex = index
} }
} }
color: {
if(FluTheme.isDark){
if(nav_list.currentIndex === index){
return "#2D2D2D"
}
if(item_mouse.containsMouse){
return "#292929"
}
return "#202020"
}else{
if(nav_list.currentIndex === index){
return "#EAEAEA"
}
if(item_mouse.containsMouse){
return "#EDEDED"
}
return "#F3f3f3"
}
}
FluText{ FluText{
text:model.text text:model.text
@ -171,8 +169,6 @@ FluWindow {
} }
} }
} }
} }

View File

@ -5,13 +5,11 @@ import QtQuick.Window 2.15
import FluentUI 1.0 import FluentUI 1.0
Item { Item {
FluText{ FluText{
id:title id:title
text:"Awesome" text:"Awesome"
fontStyle: FluText.TitleLarge fontStyle: FluText.TitleLarge
} }
FluTextBox{ FluTextBox{
id:text_box id:text_box
placeholderText: "请输入关键字" placeholderText: "请输入关键字"
@ -20,7 +18,6 @@ Item {
top:title.bottom top:title.bottom
} }
} }
FluFilledButton{ FluFilledButton{
text:"搜索" text:"搜索"
anchors{ anchors{
@ -32,7 +29,6 @@ Item {
grid_view.model = FluApp.awesomelist(text_box.text) grid_view.model = FluApp.awesomelist(text_box.text)
} }
} }
GridView{ GridView{
id:grid_view id:grid_view
cellWidth: 120 cellWidth: 120
@ -48,10 +44,8 @@ Item {
bottom: parent.bottom bottom: parent.bottom
} }
delegate: Item { delegate: Item {
width: 120 width: 120
height: 60 height: 60
FluIconButton{ FluIconButton{
id:item_icon id:item_icon
icon:modelData.icon icon:modelData.icon
@ -62,7 +56,6 @@ Item {
showSuccess("您复制了 "+text) showSuccess("您复制了 "+text)
} }
} }
FluText { FluText {
id:item_name id:item_name
font.pixelSize: 10; font.pixelSize: 10;
@ -70,10 +63,6 @@ Item {
anchors.top: item_icon.bottom anchors.top: item_icon.bottom
text: modelData.name text: modelData.name
} }
} }
} }
} }

View File

@ -1,25 +1,28 @@
import QtQuick 2.15 import QtQuick 2.15
import QtQuick.Layouts 1.15 import QtQuick.Layouts 1.15
import QtQuick.Window 2.15 import QtQuick.Window 2.15
import QtQuick.Controls 2.15
import QtGraphicalEffects 1.15 import QtGraphicalEffects 1.15
import FluentUI 1.0 import FluentUI 1.0
Item { Item {
width: parent.width width: parent.width
ColumnLayout{
spacing: 5
width: parent.width
FluText{ FluText{
id:title
text:"Buttons" text:"Buttons"
fontStyle: FluText.TitleLarge fontStyle: FluText.TitleLarge
} }
ScrollView{
clip: true
width: parent.width
contentWidth: parent.width
anchors{
top: title.bottom
bottom: parent.bottom
}
ColumnLayout{
spacing: 5
width: parent.width
RowLayout{ RowLayout{
Layout.topMargin: 20 Layout.topMargin: 20
width: parent.width width: parent.width
@ -41,12 +44,9 @@ Item {
text:"Disabled" text:"Disabled"
} }
} }
FluDivider{ FluDivider{
Layout.fillWidth: true ; height:1; Layout.fillWidth: true ; height:1;
} }
RowLayout{ RowLayout{
Layout.topMargin: 20 Layout.topMargin: 20
width: parent.width width: parent.width
@ -68,14 +68,9 @@ Item {
text:"Disabled" text:"Disabled"
} }
} }
FluDivider{ FluDivider{
Layout.fillWidth: true ; height:1 Layout.fillWidth: true ; height:1
} }
RowLayout{ RowLayout{
Layout.topMargin: 20 Layout.topMargin: 20
width: parent.width width: parent.width
@ -98,18 +93,14 @@ Item {
text:"Disabled" text:"Disabled"
} }
} }
FluDivider{ FluDivider{
Layout.fillWidth: true ; height:1 Layout.fillWidth: true ; height:1
} }
RowLayout{ RowLayout{
Layout.topMargin: 20 Layout.topMargin: 20
width: parent.width width: parent.width
ColumnLayout{ ColumnLayout{
spacing: 8 spacing: 8
Repeater{ Repeater{
id:repeater id:repeater
property int selecIndex : 0 property int selecIndex : 0
@ -137,5 +128,5 @@ Item {
} }
} }
} }
}
} }

33
example/T_Dialog.qml Normal file
View File

@ -0,0 +1,33 @@
import QtQuick 2.15
import QtQuick.Layouts 1.15
import QtQuick.Window 2.15
import QtQuick.Controls 2.15
import QtGraphicalEffects 1.15
import FluentUI 1.0
Item {
FluText{
id:title
text:"Dialog"
fontStyle: FluText.TitleLarge
}
ScrollView{
clip: true
width: parent.width
contentWidth: parent.width
anchors{
top: title.bottom
bottom: parent.bottom
}
ColumnLayout{
spacing: 5
FluButton{
Layout.topMargin: 20
text:"Show Dialog"
onClicked: {
}
}
}
}
}

View File

@ -1,19 +1,26 @@
import QtQuick 2.15 import QtQuick 2.15
import QtQuick.Layouts 1.15 import QtQuick.Layouts 1.15
import QtQuick.Window 2.15 import QtQuick.Window 2.15
import QtQuick.Controls 2.15
import QtGraphicalEffects 1.15 import QtGraphicalEffects 1.15
import FluentUI 1.0 import FluentUI 1.0
Item { Item {
ColumnLayout{
spacing: 5
FluText{ FluText{
id:title
text:"InfoBar" text:"InfoBar"
fontStyle: FluText.TitleLarge fontStyle: FluText.TitleLarge
} }
ScrollView{
clip: true
width: parent.width
contentWidth: parent.width
anchors{
top: title.bottom
bottom: parent.bottom
}
ColumnLayout{
spacing: 5
FluButton{ FluButton{
text:"Info" text:"Info"
@ -22,7 +29,6 @@ Item {
showInfo("这是一个Info样式的InfoBar") showInfo("这是一个Info样式的InfoBar")
} }
} }
FluButton{ FluButton{
text:"Warning" text:"Warning"
Layout.topMargin: 20 Layout.topMargin: 20
@ -30,7 +36,6 @@ Item {
showWarning("这是一个Warning样式的InfoBar") showWarning("这是一个Warning样式的InfoBar")
} }
} }
FluButton{ FluButton{
text:"Error" text:"Error"
Layout.topMargin: 20 Layout.topMargin: 20
@ -38,7 +43,6 @@ Item {
showError("这是一个Error样式的InfoBar") showError("这是一个Error样式的InfoBar")
} }
} }
FluButton{ FluButton{
text:"Success" text:"Success"
Layout.topMargin: 20 Layout.topMargin: 20
@ -46,9 +50,6 @@ Item {
showSuccess("这是一个Success样式的InfoBar这是一个Success样式的InfoBar") showSuccess("这是一个Success样式的InfoBar这是一个Success样式的InfoBar")
} }
} }
} }
}
} }

View File

@ -1,18 +1,26 @@
import QtQuick 2.15 import QtQuick 2.15
import QtQuick.Layouts 1.15 import QtQuick.Layouts 1.15
import QtQuick.Window 2.15 import QtQuick.Window 2.15
import QtQuick.Controls 2.15
import QtGraphicalEffects 1.15 import QtGraphicalEffects 1.15
import FluentUI 1.0 import FluentUI 1.0
Item { Item {
ColumnLayout{
spacing: 5
FluText{ FluText{
id:title
text:"Progress" text:"Progress"
fontStyle: FluText.TitleLarge fontStyle: FluText.TitleLarge
} }
ScrollView{
clip: true
width: parent.width
contentWidth: parent.width
anchors{
top: title.bottom
bottom: parent.bottom
}
ColumnLayout{
spacing: 5
FluProgressBar{ FluProgressBar{
Layout.topMargin: 20 Layout.topMargin: 20
} }
@ -29,7 +37,6 @@ Item {
Layout.topMargin: 10 Layout.topMargin: 10
indeterminate: false indeterminate: false
} }
FluSlider{ FluSlider{
Layout.topMargin: 30 Layout.topMargin: 30
value:50 value:50
@ -39,4 +46,5 @@ Item {
} }
} }
} }
}
} }

View File

@ -1,72 +1,72 @@
import QtQuick 2.15 import QtQuick 2.15
import QtQuick.Layouts 1.15 import QtQuick.Layouts 1.15
import QtQuick.Controls 2.15
import QtQuick.Window 2.15 import QtQuick.Window 2.15
import QtGraphicalEffects 1.15 import QtGraphicalEffects 1.15
import FluentUI 1.0 import FluentUI 1.0
Item { Item {
ColumnLayout{
spacing: 5
FluText{ FluText{
id:title
text:"Rectangle" text:"Rectangle"
fontStyle: FluText.TitleLarge fontStyle: FluText.TitleLarge
} }
ScrollView{
clip: true
width: parent.width
contentWidth: parent.width
anchors{
top: title.bottom
bottom: parent.bottom
}
ColumnLayout{
spacing: 5
width: parent.width
height: parent.height
RowLayout{ RowLayout{
Layout.topMargin: 20 Layout.topMargin: 20
FluRectangle{ FluRectangle{
width: 50 width: 50
height: 50 height: 50
color:"#0078d4" color:"#0078d4"
radius:[0,0,0,0] radius:[0,0,0,0]
} }
FluRectangle{ FluRectangle{
width: 50 width: 50
height: 50 height: 50
color:"#744da9" color:"#744da9"
radius:[15,15,15,15] radius:[15,15,15,15]
} }
FluRectangle{ FluRectangle{
width: 50 width: 50
height: 50 height: 50
color:"#ffeb3b" color:"#ffeb3b"
radius:[15,0,0,0] radius:[15,0,0,0]
} }
FluRectangle{ FluRectangle{
width: 50 width: 50
height: 50 height: 50
color:"#f7630c" color:"#f7630c"
radius:[0,15,0,0] radius:[0,15,0,0]
} }
FluRectangle{ FluRectangle{
width: 50 width: 50
height: 50 height: 50
color:"#e71123" color:"#e71123"
radius:[0,0,15,0] radius:[0,0,15,0]
} }
FluRectangle{ FluRectangle{
width: 50 width: 50
height: 50 height: 50
color:"#b4009e" color:"#b4009e"
radius:[0,0,0,15] radius:[0,0,0,15]
} }
} }
FluText{ FluText{
text:"配合图片使用" text:"配合图片使用"
fontStyle: FluText.Subtitle fontStyle: FluText.Subtitle
Layout.topMargin: 20 Layout.topMargin: 20
} }
RowLayout{ RowLayout{
spacing: 14 spacing: 14
FluRectangle{ FluRectangle{
@ -114,7 +114,6 @@ Item {
} }
} }
} }
FluRectangle{ FluRectangle{
width: 1080/5 width: 1080/5
height: 1439/5 height: 1439/5
@ -128,4 +127,5 @@ Item {
Layout.topMargin: 10 Layout.topMargin: 10
} }
} }
}
} }

View File

@ -1,27 +1,30 @@
import QtQuick 2.15 import QtQuick 2.15
import QtQuick.Layouts 1.15 import QtQuick.Layouts 1.15
import QtQuick.Window 2.15 import QtQuick.Window 2.15
import QtQuick.Controls 2.15
import QtGraphicalEffects 1.15 import QtGraphicalEffects 1.15
import FluentUI 1.0 import FluentUI 1.0
Item { Item {
ColumnLayout{
spacing: 5
FluText{ FluText{
id:title
text:"Slider" text:"Slider"
fontStyle: FluText.TitleLarge fontStyle: FluText.TitleLarge
} }
ScrollView{
clip: true
width: parent.width
contentWidth: parent.width
anchors{
top: title.bottom
bottom: parent.bottom
}
ColumnLayout{
spacing: 5
FluSlider{ FluSlider{
Layout.topMargin: 20 Layout.topMargin: 20
value: 50 value: 50
} }
} }
}
} }

View File

@ -6,14 +6,21 @@ import QtGraphicalEffects 1.15
import FluentUI 1.0 import FluentUI 1.0
Item { Item {
ColumnLayout{
spacing: 5
FluText{ FluText{
id:title
text:"TextBox" text:"TextBox"
fontStyle: FluText.TitleLarge fontStyle: FluText.TitleLarge
} }
ScrollView{
clip: true
width: parent.width
contentWidth: parent.width
anchors{
top: title.bottom
bottom: parent.bottom
}
ColumnLayout{
spacing: 5
FluTextBox{ FluTextBox{
Layout.topMargin: 20 Layout.topMargin: 20
placeholderText: "单行输入框" placeholderText: "单行输入框"
@ -25,4 +32,5 @@ Item {
placeholderText: "多行输入框" placeholderText: "多行输入框"
} }
} }
}
} }

View File

@ -1,22 +1,28 @@
import QtQuick 2.15 import QtQuick 2.15
import QtQuick.Layouts 1.15 import QtQuick.Layouts 1.15
import QtQuick.Window 2.15 import QtQuick.Window 2.15
import QtQuick.Controls 2.15
import QtGraphicalEffects 1.15 import QtGraphicalEffects 1.15
import FluentUI 1.0 import FluentUI 1.0
Item { Item {
ColumnLayout{
spacing: 5
FluText{ FluText{
id:title
text:"Theme" text:"Theme"
fontStyle: FluText.TitleLarge fontStyle: FluText.TitleLarge
} }
ScrollView{
clip: true
width: parent.width
contentWidth: parent.width
anchors{
top: title.bottom
bottom: parent.bottom
}
ColumnLayout{
spacing: 5
RowLayout{ RowLayout{
Layout.topMargin: 20 Layout.topMargin: 20
Repeater{ Repeater{
model: [FluColors.Yellow,FluColors.Orange,FluColors.Red,FluColors.Magenta,FluColors.Purple,FluColors.Blue,FluColors.Teal,FluColors.Green] model: [FluColors.Yellow,FluColors.Orange,FluColors.Red,FluColors.Magenta,FluColors.Purple,FluColors.Blue,FluColors.Teal,FluColors.Green]
delegate: Rectangle{ delegate: Rectangle{
@ -43,4 +49,5 @@ Item {
} }
} }
} }
}
} }

View File

@ -1,26 +1,30 @@
import QtQuick 2.15 import QtQuick 2.15
import QtQuick.Layouts 1.15 import QtQuick.Layouts 1.15
import QtQuick.Window 2.15 import QtQuick.Window 2.15
import QtQuick.Controls 2.15
import QtGraphicalEffects 1.15 import QtGraphicalEffects 1.15
import FluentUI 1.0 import FluentUI 1.0
Item { Item {
ColumnLayout{
spacing: 5
FluText{ FluText{
id:title
text:"ToggleSwitch" text:"ToggleSwitch"
fontStyle: FluText.TitleLarge fontStyle: FluText.TitleLarge
} }
ScrollView{
clip: true
width: parent.width
contentWidth: parent.width
anchors{
top: title.bottom
bottom: parent.bottom
}
ColumnLayout{
spacing: 5
FluToggleSwitch{ FluToggleSwitch{
Layout.topMargin: 20 Layout.topMargin: 20
} }
} }
}
} }

View File

@ -1,54 +1,56 @@
import QtQuick 2.15 import QtQuick 2.15
import QtQuick.Layouts 1.15 import QtQuick.Layouts 1.15
import QtQuick.Controls 2.15
import FluentUI 1.0 import FluentUI 1.0
Item { Item {
FluText{
id:title
text:"Theme"
fontStyle: FluText.TitleLarge
}
ScrollView{
clip: true
width: parent.width
contentWidth: parent.width
anchors{
top: title.bottom
bottom: parent.bottom
}
ColumnLayout{ ColumnLayout{
spacing: 5 spacing: 5
FluText{ FluText{
text:"Display" text:"Display"
fontStyle: FluText.Display fontStyle: FluText.Display
} }
FluText{ FluText{
text:"Title Large" text:"Title Large"
fontStyle: FluText.TitleLarge fontStyle: FluText.TitleLarge
} }
FluText{ FluText{
text:"Title" text:"Title"
fontStyle: FluText.Title fontStyle: FluText.Title
} }
FluText{ FluText{
text:"Subtitle" text:"Subtitle"
fontStyle: FluText.Subtitle fontStyle: FluText.Subtitle
} }
FluText{ FluText{
text:"Body Large" text:"Body Large"
fontStyle: FluText.BodyLarge fontStyle: FluText.BodyLarge
} }
FluText{ FluText{
text:"Body Strong" text:"Body Strong"
fontStyle: FluText.BodyStrong fontStyle: FluText.BodyStrong
} }
FluText{ FluText{
text:"Body" text:"Body"
fontStyle: FluText.Body fontStyle: FluText.Body
} }
FluText{ FluText{
text:"Caption" text:"Caption"
fontStyle: FluText.Caption fontStyle: FluText.Caption
} }
} }
}
} }

View File

@ -1,5 +1,5 @@
QT += quick concurrent QT += quick concurrent
CONFIG += c++11 qtquickcompiler utf8_source CONFIG += c++11
DEFINES += QT_DEPRECATED_WARNINGS QT_NO_WARNING_OUTPUT DEFINES += QT_DEPRECATED_WARNINGS QT_NO_WARNING_OUTPUT

View File

@ -27,5 +27,6 @@
<file>T_Awesome.qml</file> <file>T_Awesome.qml</file>
<file>T_TextBox.qml</file> <file>T_TextBox.qml</file>
<file>T_Theme.qml</file> <file>T_Theme.qml</file>
<file>T_Dialog.qml</file>
</qresource> </qresource>
</RCC> </RCC>

View File

@ -32,10 +32,6 @@ void Fluent::registerTypes(const char *uri){
qmlRegisterType<WindowHelper>(uri,major,minor,"WindowHelper"); qmlRegisterType<WindowHelper>(uri,major,minor,"WindowHelper");
qmlRegisterType<FluColorSet>(uri,major,minor,"FluColorSet"); qmlRegisterType<FluColorSet>(uri,major,minor,"FluColorSet");
// qmlRegisterSingletonType(QUrl("qrc:/com.zhuzichu/controls/FluColors.qml"),uri,major,minor,"FluColors");
// qmlRegisterSingletonType(QUrl("qrc:/com.zhuzichu/controls/FluTheme.qml"),uri,major,minor,"FluTheme");
qmlRegisterType(QUrl("qrc:/com.zhuzichu/controls/FluColorSetOld.qml"),uri,major,minor,"FluColorSetOld");
qmlRegisterType(QUrl("qrc:/com.zhuzichu/controls/FluMenu.qml"),uri,major,minor,"FluMenu"); qmlRegisterType(QUrl("qrc:/com.zhuzichu/controls/FluMenu.qml"),uri,major,minor,"FluMenu");
qmlRegisterType(QUrl("qrc:/com.zhuzichu/controls/FluMenuItem.qml"),uri,major,minor,"FluMenuItem"); qmlRegisterType(QUrl("qrc:/com.zhuzichu/controls/FluMenuItem.qml"),uri,major,minor,"FluMenuItem");

View File

@ -12,15 +12,6 @@ public:
bool m_deleteLater = false; bool m_deleteLater = false;
QQuickItem *m_titleItem = nullptr; QQuickItem *m_titleItem = nullptr;
}; };
static bool isMaxWin(QWindow* win)
{
return win->windowState() == Qt::WindowMaximized;
}
static bool isFullWin(QQuickView* win)
{
return win->windowState() == Qt::WindowFullScreen;
}
FramelessView::FramelessView(QWindow *parent) : Super(parent), d(new FramelessViewPrivate) FramelessView::FramelessView(QWindow *parent) : Super(parent), d(new FramelessViewPrivate)
{ {
setFlags(Qt::CustomizeWindowHint | Qt::Window | Qt::FramelessWindowHint | Qt::WindowMinMaxButtonsHint | Qt::WindowTitleHint | Qt::WindowSystemMenuHint); setFlags(Qt::CustomizeWindowHint | Qt::Window | Qt::FramelessWindowHint | Qt::WindowMinMaxButtonsHint | Qt::WindowTitleHint | Qt::WindowSystemMenuHint);
@ -109,53 +100,6 @@ bool FramelessView::nativeEvent(const QByteArray &eventType, void *message, qint
bool FramelessView::nativeEvent(const QByteArray &eventType, void *message, long *result) bool FramelessView::nativeEvent(const QByteArray &eventType, void *message, long *result)
#endif #endif
{ {
if (!result)
{
return false;
}
#if (QT_VERSION == QT_VERSION_CHECK(5, 11, 1))
const auto msg = *reinterpret_cast<MSG**>(message);
#else
const auto msg = static_cast<LPMSG>(message);
#endif
if (!msg || !msg->hwnd)
{
return false;
}
switch (msg->message)
{
case WM_NCCALCSIZE: {
#if 1
const auto mode = static_cast<BOOL>(msg->wParam);
const auto clientRect = mode ? &(reinterpret_cast<LPNCCALCSIZE_PARAMS>(msg->lParam)->rgrc[0]) : reinterpret_cast<LPRECT>(msg->lParam);
if (mode == TRUE)
{
*result = WVR_REDRAW;
//规避 拖动border进行resize时界面闪烁
if (!isMaxWin(this) && !isFullWin(this))
{
if (clientRect->top != 0)
{
clientRect->top -= 0.1;
}
}
else
{
if (clientRect->top != 0)
{
clientRect->top += 0.1;
}
}
return true;
}
#else
*result = 0;
return true;
#endif
break;
}
}
return Super::nativeEvent(eventType, message, result); return Super::nativeEvent(eventType, message, result);
} }

View File

@ -6,7 +6,13 @@ import FluentUI 1.0
Rectangle{ Rectangle{
id:root id:root
color: FluTheme.isDark ? FluTheme.primaryColor.lighter : FluTheme.primaryColor.dark
property color borerlessColor : FluTheme.isDark ? FluTheme.primaryColor.lighter : FluTheme.primaryColor.dark
color: {
if(Window.window == null)
return borerlessColor
return Window.window.active ? borerlessColor : Qt.lighter(FluTheme.primaryColor.lightest,1.1)
}
height: 50 height: 50
width: { width: {
if(parent==null) if(parent==null)
@ -19,30 +25,31 @@ Rectangle{
property bool showDark: false property bool showDark: false
property bool showFps: false property bool showFps: false
property var window: Window.window
property bool resizable: { property bool resizable: {
if(Window.window == null){ if(window == null){
return false return false
} }
return !(Window.window.minimumHeight === Window.window.maximumHeight && Window.window.maximumWidth === Window.window.minimumWidth) return !(window.minimumHeight === window.maximumHeight && window.maximumWidth === window.minimumWidth)
} }
MouseArea{ TapHandler {
anchors.fill: parent onTapped: if (tapCount === 2) toggleMaximized()
anchors.topMargin: 5 gesturePolicy: TapHandler.DragThreshold
acceptedButtons: Qt.LeftButton
hoverEnabled: true
onPressed: Window.window.startSystemMove()
onDoubleClicked: {
if(resizable)
toggleMaximized();
} }
DragHandler {
target: null
grabPermissions: TapHandler.CanTakeOverFromAnything
onActiveChanged: if (active) { window.startSystemMove(); }
} }
function toggleMaximized() { function toggleMaximized() {
if (Window.window.visibility === Window.Maximized) { if (window.visibility === Window.Maximized) {
Window.window.showNormal(); window.showNormal();
} else { } else {
Window.window.showMaximized(); window.showMaximized();
} }
} }
@ -98,14 +105,14 @@ Rectangle{
textColor: root.textColor textColor: root.textColor
color:hovered ? "#20000000" : "#00000000" color:hovered ? "#20000000" : "#00000000"
onClicked: { onClicked: {
Window.window.showMinimized() window.showMinimized()
} }
} }
FluIconButton{ FluIconButton{
property bool isRestore:{ property bool isRestore:{
if(Window.window == null) if(window == null)
return false return false
return Window.Maximized === Window.window.visibility return Window.Maximized === window.visibility
} }
icon : isRestore ? FluentIcons.FA_window_restore : FluentIcons.FA_window_maximize icon : isRestore ? FluentIcons.FA_window_restore : FluentIcons.FA_window_maximize
color:hovered ? "#20000000" : "#00000000" color:hovered ? "#20000000" : "#00000000"

View File

@ -1,13 +0,0 @@
import QtQuick 2.15
QtObject {
property color darkest: Qt.rgba(0/255,74/255,131/255,1)
property color darker:Qt.rgba(0/255,84/255,148/255,1)
property color dark:Qt.rgba(0/255,102/255,180/255,1)
property color normal:Qt.rgba(0/255,120/255,212/255,1)
property color light:Qt.rgba(38/255,140/255,218/255,1)
property color lighter:Qt.rgba(76/255,160/255,224/255,1)
property color lightest:Qt.rgba(96/255,171/255,228/255,1)
}

View File

@ -1,112 +0,0 @@
pragma Singleton
import QtQuick 2.15
QtObject {
property color _Black: Qt.rgba(0/255,0/255,0/255,1)
property color _White: Qt.rgba(255/255,255/255,255/255,1)
property color _Grey10: Qt.rgba(250/255,249/255,248/255,1)
property color _Grey20: Qt.rgba(243/255,242/255,241/255,1)
property color _Grey30: Qt.rgba(237/255,235/255,233/255,1)
property color _Grey40: Qt.rgba(225/255,223/255,221/255,1)
property color _Grey50: Qt.rgba(210/255,208/255,206/255,1)
property color _Grey60: Qt.rgba(200/255,198/255,196/255,1)
property color _Grey70: Qt.rgba(190/255,187/255,184/255,1)
property color _Grey80: Qt.rgba(179/255,176/255,173/255,1)
property color _Grey90: Qt.rgba(161/255,159/255,157/255,1)
property color _Grey100: Qt.rgba(151/255,149/255,147/255,1)
property color _Grey110: Qt.rgba(138/255,136/255,134/255,1)
property color _Grey120: Qt.rgba(121/255,119/255,117/255,1)
property color _Grey130: Qt.rgba(96/255,94/255,92/255,1)
property color _Grey140: Qt.rgba(72/255,70/255,68/255,1)
property color _Grey150: Qt.rgba(59/255,58/255,57/255,1)
property color _Grey160: Qt.rgba(50/255,49/255,48/255,1)
property color _Grey170: Qt.rgba(41/255,40/255,39/255,1)
property color _Grey180: Qt.rgba(37/255,36/255,35/255,1)
property color _Grey190: Qt.rgba(32/255,31/255,30/255,1)
property color _Grey200: Qt.rgba(27/255,26/255,25/255,1)
property color _Grey210: Qt.rgba(22/255,21/255,20/255,1)
property color _Grey220: Qt.rgba(17/255,16/255,15/255,1)
property FluColorSetOld _Yellow:FluColorSetOld{
darkest: Qt.rgba(249/255,168/255,37/255,1)
darker:Qt.rgba(251/255,192/255,45/255,1)
dark:Qt.rgba(253/255,216/255,53/255,1)
normal:Qt.rgba(255/255,235/255,59/255,1)
light:Qt.rgba(255/255,238/255,88/255,1)
lighter:Qt.rgba(255/255,241/255,118/255,1)
lightest:Qt.rgba(255/255,245/255,157/255,1)
}
property FluColorSetOld _Orange:FluColorSetOld{
darkest: Qt.rgba(153/255,61/255,7/255,1)
darker:Qt.rgba(172/255,68/255,8/255,1)
dark:Qt.rgba(209/255,84/255,10/255,1)
normal:Qt.rgba(247/255,99/255,12/255,1)
light:Qt.rgba(248/255,122/255,48/255,1)
lighter:Qt.rgba(249/255,145/255,84/255,1)
lightest:Qt.rgba(250/255,158/255,104/255,1)
}
property FluColorSetOld _Red:FluColorSetOld{
darkest: Qt.rgba(143/255,10/255,21/255,1)
darker:Qt.rgba(162/255,11/255,24/255,1)
dark:Qt.rgba(185/255,13/255,28/255,1)
normal:Qt.rgba(232/255,17/255,35/255,1)
light:Qt.rgba(236/255,64/255,79/255,1)
lighter:Qt.rgba(238/255,88/255,101/255,1)
lightest:Qt.rgba(240/255,107/255,118/255,1)
}
property FluColorSetOld _Magenta:FluColorSetOld{
darkest: Qt.rgba(111/255,0/255,79/255,1)
darker:Qt.rgba(126/255,0/255,110/255,1)
dark:Qt.rgba(144/255,0/255,126/255,1)
normal:Qt.rgba(180/255,0/255,158/255,1)
light:Qt.rgba(195/255,51/255,177/255,1)
lighter:Qt.rgba(202/255,76/255,187/255,1)
lightest:Qt.rgba(208/255,96/255,194/255,1)
}
property FluColorSetOld _Purple:FluColorSetOld{
darkest: Qt.rgba(71/255,47/255,104/255,1)
darker:Qt.rgba(81/255,53/255,118/255,1)
dark:Qt.rgba(100/255,66/255,147/255,1)
normal:Qt.rgba(116/255,77/255,169/255,1)
light:Qt.rgba(134/255,100/255,180/255,1)
lighter:Qt.rgba(157/255,130/255,194/255,1)
lightest:Qt.rgba(168/255,144/255,201/255,1)
}
property FluColorSetOld _Blue:FluColorSetOld{
darkest: Qt.rgba(0/255,74/255,131/255,1)
darker:Qt.rgba(0/255,84/255,148/255,1)
dark:Qt.rgba(0/255,102/255,180/255,1)
normal:Qt.rgba(0/255,120/255,212/255,1)
light:Qt.rgba(38/255,140/255,218/255,1)
lighter:Qt.rgba(76/255,160/255,224/255,1)
lightest:Qt.rgba(96/255,171/255,228/255,1)
}
property FluColorSetOld _Teal:FluColorSetOld{
darkest: Qt.rgba(0/255,110/255,91/255,1)
darker:Qt.rgba(0/255,124/255,103/255,1)
dark:Qt.rgba(0/255,151/255,125/255,1)
normal:Qt.rgba(0/255,178/255,148/255,1)
light:Qt.rgba(38/255,189/255,164/255,1)
lighter:Qt.rgba(76/255,201/255,180/255,1)
lightest:Qt.rgba(96/255,207/255,188/255,1)
}
property FluColorSetOld _Green:FluColorSetOld{
darkest: Qt.rgba(9/255,76/255,9/255,1)
darker:Qt.rgba(12/255,93/255,12/255,1)
dark:Qt.rgba(14/255,111/255,14/255,1)
normal:Qt.rgba(16/255,124/255,16/255,1)
light:Qt.rgba(39/255,137/255,39/255,1)
lighter:Qt.rgba(75/255,156/255,75/255,1)
lightest:Qt.rgba(106/255,173/255,106/255,1)
}
}

View File

@ -1,10 +0,0 @@
pragma Singleton
import QtQuick 2.15
QtObject {
property FluColorSetOld primaryColor: FluColorsOld._Teal
}

View File

@ -20,18 +20,20 @@ Item {
property int maximumWidth property int maximumWidth
property int minimumHeight property int minimumHeight
property int maximumHeight property int maximumHeight
property int borderless:{ property int borderless:{
if(Window.window == null) if(window === null)
return 4 return 4
if(Window.window.visibility === Window.Maximized){ if(Window.window.visibility === Window.Maximized){
return 0 return 0
} }
return 4 return 4
} }
default property alias content: container.children default property alias content: container.data
FluWindowResize{}
FluWindowResize{
border:borderless
}
Behavior on opacity{ Behavior on opacity{
NumberAnimation{ NumberAnimation{
@ -39,13 +41,17 @@ Item {
} }
} }
Rectangle{ Rectangle{
color: FluTheme.isDark ? FluTheme.primaryColor.lighter : FluTheme.primaryColor.dark property color borerlessColor : FluTheme.isDark ? FluTheme.primaryColor.lighter : FluTheme.primaryColor.dark
color: {
if(window === null)
return borerlessColor
return window.active ? borerlessColor : Qt.lighter(FluTheme.primaryColor.lightest,1.1)
}
border.width: 1 border.width: 1
anchors.fill: parent anchors.fill: parent
radius: 4 radius: 4
border.color:FluTheme.isDark ? Qt.darker(FluTheme.primaryColor.lighter,1.3) : Qt.lighter(FluTheme.primaryColor.dark,1.3) border.color:FluTheme.isDark ? Qt.darker(FluTheme.primaryColor.lighter,1.3) : Qt.lighter(FluTheme.primaryColor.dark,1.2)
} }
Rectangle{ Rectangle{

View File

@ -4,13 +4,14 @@ import QtQuick.Window 2.15
MouseArea { MouseArea {
property int border: 4 property int border: 4
property var window: Window.window
property bool fixedSize: { property bool fixedSize: {
if(Window.window == null) if(window == null)
return true return true
if(Window.window.visibility === Window.Maximized || Window.window.visibility === Window.FullScreen){ if(window.visibility === Window.Maximized || window.visibility === Window.FullScreen){
return true return true
} }
return (Window.window.minimumWidth === Window.window.maximumWidth && Window.window.minimumHeight === Window.window.maximumHeight) return (window.minimumWidth === window.maximumWidth && window.minimumHeight === window.maximumHeight)
} }
anchors.fill: parent anchors.fill: parent

View File

@ -32,8 +32,5 @@
<file>controls/FluMenuItem.qml</file> <file>controls/FluMenuItem.qml</file>
<file>controls/FluShadow.qml</file> <file>controls/FluShadow.qml</file>
<file>controls/FluTextButton.qml</file> <file>controls/FluTextButton.qml</file>
<file>controls/FluColorSetOld.qml</file>
<file>controls/FluColorsOld.qml</file>
<file>controls/FluThemeOld.qml</file>
</qresource> </qresource>
</RCC> </RCC>