Le frecce QSpinBox posizionano la modifica della riga esterna (css)
-
29-10-2019 - |
Domanda
(fonte: metrotek.spb.ru )
Come farlo con l'aiuto di Qt CSS?
Ho provato a usare
subcontrol-origin: margin;
position: absolute;
ma senza successo.
Grazie per qualsiasi aiuto
<”Modifica
Grazie per l'aiuto e il CSS finale per il mio problema è:
QSpinBox#spin {
margin-left: 20px; /* make room for the arrows */
margin-right: 20px; /* make room for the arrows */
width: 20px;
border: 2 solid #515151;
background-color: #434343;
}
QSpinBox#spin::up-button {
subcontrol-origin: margin;
subcontrol-position: center left;
width: 19px;
border-width: 1px;
}
QSpinBox#spin::up-arrow {
image: url(:/res/images/up.png);
min-width: 19px;
min-height: 14px;
max-width: 19px;
max-height: 14px;
height: 19px;
width: 14px;
}
QSpinBox#spin::up-button:pressed {
top: 1px;
right: 1px;
}
QSpinBox#spin::down-button {
subcontrol-origin: margin;
subcontrol-position: center right;
width: 19px;
border-width: 1px;
}
QSpinBox#spin::down-arrow {
image: url(:/res/images/down.png);
min-width: 19px;
min-height: 14px;
max-width: 19px;
max-height: 14px;
height: 19px;
width: 14px;
}
QSpinBox#spin::down-button:pressed {
top: 1px;
left: 1px;
}
e CSS aggiuntivi come bonus :) Se desideri impostare la posizione per le frecce "su, giù" al di fuori della modifica solo sul lato destro:
QSpinBox#spin {
margin-right: 40px; /* make room for the arrows */
width: 20px;
border: 2 solid #515151;
background-color: #434343;
}
QSpinBox#spin::up-button {
subcontrol-origin: margin;
subcontrol-position: center right;
position: relative;
left: -20px; /* shift position back*/
width: 19px;
border-width: 1px;
}
QSpinBox#spin::down-button {
subcontrol-origin: margin;
subcontrol-position: center right;
width: 19px;
border-width: 1px;
}
Soluzione
Hai dato un'occhiata alla guida ai fogli di stile Qt?Hanno un esempio molto specifico di come posizionare le frecce su e giù:
QSpinBox {
padding-right: 15px; /* make room for the arrows */
border-image: url(:/images/frame.png) 4;
border-width: 3;
}
QSpinBox::up-button {
subcontrol-origin: border;
subcontrol-position: top right; /* position at the top right corner */
width: 16px; /* 16 + 2*1px border-width = 15px padding + 3px parent border */
border-image: url(:/images/spinup.png) 1;
border-width: 1px;
}
QSpinBox::down-button {
subcontrol-origin: border;
subcontrol-position: bottom right; /* position at bottom right corner */
width: 16px;
border-image: url(:/images/spindown.png) 1;
border-width: 1px;
border-top-width: 0;
}
Regola semplicemente la posizione del sottocontrollo.E regola anche la spaziatura interna per QSpinBox per assegnargli anche la spaziatura a sinistra.
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow