gpt4 book ai didi

javascript - 将按钮中的标签文本和 Cinnamon Desklet 的工具提示文本向左对齐

转载 作者:行者123 更新时间:2023-11-28 01:56:59 24 4
gpt4 key购买 nike

我有一个 Cinnamon Desklet,它由一个 Button 组成。 Button 有一个 Label(带有一些文本)和一个 Tooltip:

const Desklet = imports.ui.desklet;
const St = imports.gi.St;
const Tooltips = imports.ui.tooltips;

function MyDesklet(metadata, desklet_id) {
this._init(metadata, desklet_id);
}

MyDesklet.prototype = {
__proto__: Desklet.Desklet.prototype,

_init: function(metadata, desklet_id) {
Desklet.Desklet.prototype._init.call(this, metadata, desklet_id);

this.setupUI();
},

setupUI: function() {
// main container for the desklet
this.boxLayout = new St.BoxLayout({
vertical: true,
width: 100,
height: 40
});

let label = new St.Label({text: "Label text"});
// style does not work
let button = new St.Button({child: label, style: "text-align: left;"});
let tooltip = new Tooltips.Tooltip(button,
_("Tooltip\ntext"));
// Does not work
tooltip.style = "text-align: left;";

this.boxLayout.add_actor(button);
this.setContent(this.boxLayout);
}
}

function main(metadata, desklet_id) {
return new MyDesklet(metadata, desklet_id);
}

上面的代码生成了这个 Desklet:

enter image description here

Button 中的 Label 文本和 Tooltip 文本如何左对齐而不是居中?

最佳答案

好吧...我终于弄明白了...

const Desklet = imports.ui.desklet;
const St = imports.gi.St;

function MyDesklet(metadata, desklet_id) {
this._init(metadata, desklet_id);
}

MyDesklet.prototype = {
__proto__ : Desklet.Desklet.prototype,

_init : function(metadata, desklet_id) {
Desklet.Desklet.prototype._init.call(this, metadata, desklet_id);

this.setupUI();
},

setupUI : function() {
// main container for the desklet
this.boxLayout = new St.BoxLayout({
vertical : true,
width : 100,
height : 40
});

let label = new St.Label({text : "Label text"});
// 'x_align' aligns the Label inside the Button
let button = new St.Button({
child: label,
x_align: St.Align.START
});
let tooltip = new Tooltip(button, _("Tooltip\ntext"));
// Use custom method 'set_style()' to set Tooltip style
tooltip.set_style("text-align: left;");

this.boxLayout.add_actor(button);
this.setContent(this.boxLayout);
}
}

function main(metadata, desklet_id) {
return new MyDesklet(metadata, desklet_id);
}

// Custom Tooltip with set_style()
function Tooltip(actor, text) {
this._init(actor, text);
}
Tooltip.prototype = {
__proto__: imports.ui.tooltips.Tooltip.prototype,

_init: function(actor, text) {
imports.ui.tooltips.Tooltip.prototype._init.call(this, actor, text);
},

// Method to set Tooltip style
set_style: function(style) {
this._tooltip.set_style(style);
}
};

结果:

Screenshot of resulting Desklet

关于javascript - 将按钮中的标签文本和 Cinnamon Desklet 的工具提示文本向左对齐,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49568802/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com