2017-12-04 26 views
0

Python & Kivyで可能かどうかを知りたいのですが、HTML/CSSのようなTextInputウィジェットをカスタマイズできます。私のCustomTextInput(TextInput)クラスにそれを直接行う方法はありますか?Kivy:TextInputボーダー半径

私は私のTextInputは次のようになりたい:もちろん

what I want to obtain

答えて

1

することができますが、それはkivyに少し複雑です:

test.kv

#:import C kivy.utils.get_color_from_hex 

<[email protected]>: 
    font_size: '14dp' 
    background_color: 0,0,0,0 
    cursor_color: C('#ffffff') 
    canvas.before: 
     Color: 
      rgba: C('#ffffff') 
    canvas.after: 
     Color: 
      rgb: C('#0f192e') 
     Ellipse: 
      angle_start:180 
      angle_end:360 
      pos:(self.pos[0] - self.size[1]/2.0, self.pos[1]) 
      size: (self.size[1], self.size[1]) 
     Ellipse: 
      angle_start:360 
      angle_end:540 
      pos: (self.size[0] + self.pos[0] - self.size[1]/2.0, self.pos[1]) 
      size: (self.size[1], self.size[1]) 
     Color: 
      rgba: C('#3f92db') 
     Line: 
      points: self.pos[0] , self.pos[1], self.pos[0] + self.size[0], self.pos[1] 
     Line: 
      points: self.pos[0], self.pos[1] + self.size[1], self.pos[0] + self.size[0], self.pos[1] + self.size[1] 
     Line: 
      ellipse: self.pos[0] - self.size[1]/2.0, self.pos[1], self.size[1], self.size[1], 180, 360 
     Line: 
      ellipse: self.size[0] + self.pos[0] - self.size[1]/2.0, self.pos[1], self.size[1], self.size[1], 360, 540 

BoxLayout: 
    orientation:'vertical' 
    BoxLayout: 
     size_hint_y: 20 
     canvas.before: 
      Color: 
       rgba: C('#3f92db') 
      Rectangle: 
       pos:self.pos 
       size:self.size 
    BoxLayout: 
     orientation: 'vertical' 
     size_hint_y: 80 
     canvas: 
      Color: 
       rgba: C('#18294a') 
      Rectangle: 
       pos:self.pos 
       size:self.size 
     BoxLayout: 
      size_hint_y: 10 
     BoxLayout: 
      size_hint_y: 20 
      orientation:'vertical' 
      Label: 
       size_hint_y: 8 
       text: 'Password' 
       color: C('#ffffff') 
       font_size:'20dp' 
       padding: 5,5 
       text_size: self.size 
       halign: 'center' 
       valign: 'center' 
      BoxLayout: 
       size_hint_y: 8 
       BoxLayout: 
        size_hint_x: 25 
       BoxLayout: 
        size_hint_x: 50 
        canvas.before: 
         Color: 
          rgba: C('#0f192e') 
         Rectangle: 
          pos: self.pos 
          size: self.size 
        MyTextInput: 
       BoxLayout: 
        size_hint_x: 25 
     BoxLayout: 
      size_hint_y: 10 
     BoxLayout: 
      size_hint_y: 20 
      orientation:'vertical' 
      Label: 
       size_hint_y: 8 
       text: 'Confirm' 
       color: C('#ffffff') 
       font_size:'20dp' 
       padding: 5,5 
       text_size: self.size 
       halign: 'center' 
       valign: 'center' 
      BoxLayout: 
       size_hint_y: 8 
       BoxLayout: 
        size_hint_x: 25 
       BoxLayout: 
        size_hint_x: 50 
        canvas.before: 
         Color: 
          rgba: C('#0f192e') 
         Rectangle: 
          pos: self.pos 
          size: self.size 
        MyTextInput: 
       BoxLayout: 
        size_hint_x: 25 
     BoxLayout: 
      size_hint_y: 40 

pythonファイル:

from kivy.app import App 


class TestApp(App): 
    pass 

if __name__ == '__main__': 
    TestApp().run() 

出力:

output

+0

ありがとう、あなたは天才<3です私は後でそれを試してみて、私はあなたが歓迎されている –

+0

いくつか質問があれば、何の問題を尋ねません –

関連する問題