2021-02-25 19:04:14 +08:00
|
|
|
import QtQuick 2.12
|
|
|
|
import QtQuick.Controls 2.5
|
2021-05-25 11:30:11 +08:00
|
|
|
import QtGraphicalEffects 1.12
|
2021-03-18 11:27:26 +08:00
|
|
|
|
2021-03-16 15:20:46 +08:00
|
|
|
import "util.mjs" as Util
|
2021-03-18 11:27:26 +08:00
|
|
|
import "gravity.mjs" as Gravity
|
2021-02-25 19:04:14 +08:00
|
|
|
|
2021-05-27 16:07:09 +08:00
|
|
|
Text {
|
|
|
|
Rectangle {
|
|
|
|
id: bg
|
|
|
|
color: 'transparent'
|
|
|
|
z: -1
|
|
|
|
}
|
|
|
|
|
2021-05-26 15:47:44 +08:00
|
|
|
FontLoader { id: webFont }
|
|
|
|
|
2021-04-06 16:14:43 +08:00
|
|
|
property var wrapper
|
2021-03-19 16:13:02 +08:00
|
|
|
|
2021-03-16 15:20:46 +08:00
|
|
|
property var uuid: Util.uuidv4()
|
2021-03-15 15:30:17 +08:00
|
|
|
|
2021-03-16 15:20:46 +08:00
|
|
|
property var tag: "Text"
|
|
|
|
|
2021-04-16 16:44:08 +08:00
|
|
|
leftPadding: 0
|
|
|
|
topPadding: 0
|
|
|
|
rightPadding: 0
|
|
|
|
bottomPadding: 0
|
|
|
|
|
2021-04-08 17:37:10 +08:00
|
|
|
property int textAlignment: 0
|
|
|
|
|
2021-05-26 15:47:44 +08:00
|
|
|
property var fontSource: ""
|
|
|
|
|
2021-06-08 20:23:58 +08:00
|
|
|
elide: Text.ElideRight
|
|
|
|
|
2021-05-26 15:47:44 +08:00
|
|
|
onFontSourceChanged: {
|
|
|
|
webFont.source = fontSource
|
|
|
|
font.family = webFont.name
|
|
|
|
}
|
|
|
|
|
2021-05-19 14:27:44 +08:00
|
|
|
property var fontStyle: ""
|
|
|
|
|
|
|
|
onFontStyleChanged: {
|
|
|
|
if (fontStyle === "bold") {
|
|
|
|
font.weight = Font.Bold
|
|
|
|
} else if (fontStyle === "italic") {
|
|
|
|
font.italic = true
|
|
|
|
} else if (fontStyle === "bold_italic") {
|
|
|
|
font.weight = Font.Bold
|
|
|
|
font.italic = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-08 17:37:10 +08:00
|
|
|
property var backgroundColor
|
2021-03-16 15:20:46 +08:00
|
|
|
|
2021-04-08 17:37:10 +08:00
|
|
|
onBackgroundColorChanged: {
|
|
|
|
bg.color = backgroundColor
|
2021-03-16 15:20:46 +08:00
|
|
|
}
|
|
|
|
|
2021-04-16 18:40:52 +08:00
|
|
|
horizontalAlignment: TextInput.AlignHCenter
|
|
|
|
verticalAlignment: TextInput.AlignVCenter
|
|
|
|
|
2021-04-08 17:37:10 +08:00
|
|
|
onTextAlignmentChanged: {
|
|
|
|
let gravity = Gravity.enumerate()
|
|
|
|
let result = this.textAlignment | gravity.CENTER_Y
|
|
|
|
console.log(tag, uuid + " onTextAlignmentChanged: " + this.textAlignment)
|
|
|
|
switch(result) {
|
|
|
|
case gravity.CENTER:
|
|
|
|
this.horizontalAlignment = TextInput.AlignHCenter
|
|
|
|
this.verticalAlignment = TextInput.AlignVCenter
|
|
|
|
break
|
2021-03-18 11:27:26 +08:00
|
|
|
}
|
2021-03-04 17:44:54 +08:00
|
|
|
}
|
2021-03-18 11:49:52 +08:00
|
|
|
|
2021-04-08 17:37:10 +08:00
|
|
|
onWidthChanged: {
|
2021-04-14 12:42:03 +08:00
|
|
|
bg.implicitWidth = width
|
2021-04-13 21:14:17 +08:00
|
|
|
console.log(tag, uuid + " onWidthChanged: " + this.width)
|
2021-04-08 17:37:10 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
onHeightChanged: {
|
2021-04-14 12:42:03 +08:00
|
|
|
bg.implicitHeight = height
|
2021-04-13 21:14:17 +08:00
|
|
|
console.log(tag, uuid + " onHeightChanged: " + this.height)
|
2021-04-08 17:37:10 +08:00
|
|
|
}
|
|
|
|
|
2021-04-19 14:05:21 +08:00
|
|
|
onTextChanged: {
|
|
|
|
console.log(tag, uuid + " onTextChanged: " + this.text)
|
|
|
|
}
|
|
|
|
|
|
|
|
property var borderWidth: 0
|
|
|
|
onBorderWidthChanged: {
|
|
|
|
bg.border.width = borderWidth
|
|
|
|
}
|
|
|
|
|
|
|
|
property var borderColor: ""
|
|
|
|
onBorderColorChanged: {
|
|
|
|
bg.border.color = borderColor
|
|
|
|
}
|
|
|
|
|
2021-03-18 11:49:52 +08:00
|
|
|
MouseArea {
|
|
|
|
anchors.fill: parent
|
|
|
|
onClicked: {
|
2021-04-07 10:41:34 +08:00
|
|
|
console.log(tag, uuid + " wrapper: " + wrapper)
|
2021-03-19 16:13:02 +08:00
|
|
|
mouseAreaBridge.onClick(wrapper)
|
2021-03-18 11:49:52 +08:00
|
|
|
}
|
|
|
|
}
|
2021-05-25 11:30:11 +08:00
|
|
|
|
|
|
|
property var shadowColor
|
|
|
|
property var shadowRadius
|
|
|
|
property var shadowOffsetX
|
|
|
|
property var shadowOffsetY
|
|
|
|
property var shadowOpacity
|
|
|
|
|
|
|
|
onShadowOpacityChanged: {
|
|
|
|
if (shadowOpacity > 0) {
|
|
|
|
layer.enabled = true
|
|
|
|
} else {
|
|
|
|
layer.enabled = false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
layer.enabled: false
|
|
|
|
layer.effect: DropShadow {
|
|
|
|
horizontalOffset: shadowOffsetX
|
|
|
|
verticalOffset: shadowOffsetY
|
|
|
|
radius: shadowRadius
|
|
|
|
samples: 16
|
|
|
|
color: shadowColor
|
|
|
|
transparentBorder: true
|
|
|
|
}
|
2021-05-25 12:42:14 +08:00
|
|
|
|
2021-05-27 16:18:44 +08:00
|
|
|
property var htmlText: false
|
|
|
|
|
|
|
|
onHtmlTextChanged: {
|
|
|
|
if (htmlText) {
|
|
|
|
textFormat = TextEdit.RichText
|
|
|
|
}
|
|
|
|
}
|
2021-05-25 14:44:42 +08:00
|
|
|
|
|
|
|
property var strikethrough: false
|
|
|
|
|
|
|
|
onStrikethroughChanged: {
|
|
|
|
font.strikeout = strikethrough
|
|
|
|
}
|
|
|
|
|
|
|
|
property var underline: false
|
|
|
|
|
|
|
|
onUnderlineChanged: {
|
|
|
|
font.underline = underline
|
|
|
|
}
|
2021-05-27 16:07:09 +08:00
|
|
|
|
|
|
|
property var lineSpacing: -1
|
|
|
|
|
|
|
|
onLineSpacingChanged: {
|
|
|
|
if (lineSpacing > 0) {
|
|
|
|
lineHeightMode = Text.FixedHeight
|
|
|
|
lineHeight = lineSpacing
|
|
|
|
}
|
|
|
|
}
|
2021-02-25 19:04:14 +08:00
|
|
|
}
|