omz:forum

    • Register
    • Login
    • Search
    • Recent
    • Popular

    Welcome!

    This is the community forum for my apps Pythonista and Editorial.

    For individual support questions, you can also send an email. If you have a very short question or just want to say hello — I'm @olemoritz on Twitter.


    Change Keyboard Layout/Language

    Pythonista
    3
    26
    9351
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • brumm
      brumm last edited by brumm

      @cvp said:

      criteria

      The criteria would be the selection of the text field (language l or c). E.g. first the Latin word and then in the next text field the Cyrillic word. Something with _begin_editing ...

      1 Reply Last reply Reply Quote 0
      • brumm
        brumm last edited by

        Btw. thank you and don‘t worry i can live without it. i just wanna know if it‘s possible or not.

        stephen 1 Reply Last reply Reply Quote 0
        • stephen
          stephen @brumm last edited by

          @brumm @cvp

          after searching around.. even using objC thesebare your options to programatically change keyboard type on UITextfield..

          typedef enum {
              UIKeyboardTypeDefault,                // Default type for the current input method.
              UIKeyboardTypeASCIICapable,           // Displays a keyboard which can enter ASCII characters, non-ASCII keyboards remain active
              UIKeyboardTypeNumbersAndPunctuation,  // Numbers and assorted punctuation.
              UIKeyboardTypeURL,                    // A type optimized for URL entry (shows . / .com prominently).
              UIKeyboardTypeNumberPad,              // A number pad (0-9). Suitable for PIN entry.
              UIKeyboardTypePhonePad,               // A phone pad (1-9, *, 0, #, with letters under the numbers).
              UIKeyboardTypeNamePhonePad,           // A type optimized for entering a person's name or phone number.
              UIKeyboardTypeEmailAddress,           // A type optimized for multiple email address entry (shows space @ . prominently).
              UIKeyboardTypeDecimalPad,             // A number pad including a decimal point
              UIKeyboardTypeTwitter,                // Optimized for entering Twitter messages (shows # and @)
              UIKeyboardTypeWebSearch,              // Optimized for URL and search term entry (shows space and .)
          
              UIKeyboardTypeAlphabet = UIKeyboardTypeASCIICapable, // Deprecated
          
          } UIKeyboardType;
          
          

          sorry buddy 😕

          1 Reply Last reply Reply Quote 1
          • brumm
            brumm last edited by

            Again thank you.

            cvp 1 Reply Last reply Reply Quote 1
            • cvp
              cvp @brumm last edited by

              @brumm Quick and very very dirty script, far from finished, but only to show how it could be possible. Automatic standard keyboard for 1st TextField, and InputView for 2nd one.
              Really automatic, nothing to do, ok for lazy guys 🙄 like us
              Sorry for my Cyrillic 😂 (characters taken from Russian keyboard)
              Please try it and tell me...

              
              import ui
              from objc_util import *
              
              import ui
              from objc_util import *
              
              def SetTextFieldPad(tf,pad=None,clearButtonMode=False,undo_redo_pasteBarButtons=False,textfield_did_change=None):
              	if not pad:
              
              		pad = [
              		{'key':'й'},{'key':'ц'},{'key':'у'},{'key':'к'},{'key':'е'},{'key':'н'},{'key':'г'},{'key':'ш'},{'key':'щ'},{'key':'з'},{'key':'х'},		{'key':'back space','icon':'typb:Delete'},
              		{'key':'new row'},
              		{'key':'Ф'},{'key':'ы'},{'key':'в'},{'key':'а'},{'key':'п'},{'key':'р'},{'key':'о'},{'key':'л'},{'key':'д'},{'key':'ж'},{'key':'э'},			{'key':'done','icon':'emj:Checkmark_3'},
              		{'key':'new row'},
              		{'key':'Я'},{'key':'ч'},{'key':'с'},{'key':'м'},{'key':'и'},{'key':'т'},{'key':'ь'},{'key':'б'},{'key':'ю'},{'key':'ъ'},
              		{'key':'new row'}]
              
              	tfo = ObjCInstance(tf).textField() # UITextField is subview of ui.TextField
              	
              	def key_pressed(sender):
              
              			if sender.title == 'test':
              				return
              			tfb = sender.TextField
              			tfobjc = ObjCInstance(tfb).textField()
              			cursor = tfobjc.offsetFromPosition_toPosition_(tfobjc.beginningOfDocument(), tfobjc.selectedTextRange().start())
              			if sender.name == 'delete':
              				if cursor <= (len(tfb.text)-1):
              					tfb.text = tfb.text[:cursor] + tfb.text[cursor+1:]
              			elif sender.name == 'back space':
              				if cursor > 0:
              					#if tfb.text != '':
              					tfb.text = tfb.text[:cursor-1] + tfb.text[cursor:]
              					cursor = cursor - 1
              			elif sender.name == 'done':
              				tfb.end_editing()
              				return
              			else:
              				tfb.text = tfb.text[:cursor] + sender.title + tfb.text[cursor:]
              				cursor = cursor + 1
              				
              			if textfield_did_change:
              				textfield_did_change(tfb)
              				
              			# set cursor
              			cursor_position = tfobjc.positionFromPosition_offset_(tfobjc.beginningOfDocument(), cursor)
              			tfobjc.selectedTextRange = tfobjc.textRangeFromPosition_toPosition_(cursor_position, cursor_position)
              
              	# design your keyboard
              	# pad = [{key='functionnality',title='title',icon='icon'},...]
              	#		new row => new row
              	#		nul => no key
              	#		back space => left delete
              	#		delete => right delete
              	#		done => discard the keyboard
              	#   other => append the character
              	
              	# count the maximum width of rows
              	row_max_length = 0
              	row_length = 0
              	for pad_elem in pad:
              		if pad_elem['key'] == 'new row':
              			if row_length > row_max_length:
              				row_max_length = row_length
              			row_length = 0		
              		else:
              			row_length = row_length + 1
              	if row_length > row_max_length:
              		row_max_length = row_length
              
              	v = ui.View()
              	db = 50
              	dd = 10
              	x0 = (ui.get_screen_size()[0]-row_max_length*db-(row_max_length-1)*dd)/2
              	x = x0
              	y = dd
              
              	for pad_elem in pad:
              		if pad_elem['key'] == 'new row':
              			y = y + db + dd
              			x = x0
              		elif pad_elem['key'] == 'nul':			
              			x = x + db + dd
              		else:			
              			b = ui.Button()
              			b.name = pad_elem['key']
              			b.background_color = 'white'	# or any other color
              			b.tint_color = 'black'
              			b.corner_radius = 10 
              			b.title = ''
              			b.font = ('<system>',32)
              			if 'icon' in pad_elem:
              				b.image = ui.Image.named(pad_elem['icon']).with_rendering_mode(ui.RENDERING_MODE_ORIGINAL)
              			elif 'title' not in pad_elem:
              				b.title = pad_elem['key']
              			if 'title' in pad_elem:
              				b.title = pad_elem['title']
              
              			b.frame = (x,y,db,db)
              			b.TextField = tf # store tf as key attribute  needed when pressed
              			b.action = pad_elem.get('action', key_pressed)
              			v.add_subview(b)
              			x = x + db + dd
              	y = y + db + dd
              
              	v.width = ui.get_screen_size()[0]
              	v.height = y
              
              	# view of keyboard
              	retain_global(v) # see https://forum.omz-software.com/topic/4653/button-action-not-called-when-view-is-added-to-native-view
              	tfo.setInputView_(ObjCInstance(v))
              	
              	# color of cursor and selected text
              	tfo.tintColor = UIColor.redColor().colorWithAlphaComponent(0.5)
              	
              	# clear button
              	tfo.clearButtonMode = clearButtonMode
              
              	# comment both lines to keep undo/redo/paste BarButtons above keyboard
              	if not undo_redo_pasteBarButtons:
              		tfo.inputAssistantItem().setLeadingBarButtonGroups(None)
              		tfo.inputAssistantItem().setTrailingBarButtonGroups(None)
              
              class MyView(ui.View):
              	def __init__(self):
              		self.frame = (0,0,500,500)
              		self.background_color = 'white'
              
              		tfl = ui.TextField()
              		tfl.frame = (10,10,480,32)
              		tfl.delegate = self
              		self.add_subview(tfl)
              
              		tfc = ui.TextField()
              		tfc.frame = (10,50,480,32)
              		tfc.delegate = self
              		self.add_subview(tfc)
              		SetTextFieldPad(tfc)
              
              v = MyView()
              v.present('sheet')
              

              1 Reply Last reply Reply Quote 2
              • cvp
                cvp last edited by

                Update

                		tfl = ui.TextField()
                		tfl.frame = (10,10,480,32)
                		tfl.placeholder = 'latin'
                		tfl.delegate = self
                		self.add_subview(tfl)
                
                		tfc = ui.TextField()
                		tfc.frame = (10,50,480,32)
                		tfc.placeholder = 'cyrillic'
                		tfc.delegate = self
                		self.add_subview(tfc)
                		SetTextFieldPad(tfc) 
                

                1 Reply Last reply Reply Quote 1
                • brumm
                  brumm last edited by

                  Looks great, спасибо.

                  cvp 1 Reply Last reply Reply Quote 0
                  • cvp
                    cvp @brumm last edited by

                    @brumm Never mind. Did you try it? Is something like that (I know that it is not exactly that) you want?

                    1 Reply Last reply Reply Quote 0
                    • brumm
                      brumm last edited by

                      I thought there is an easy solution, but that is also great, because when you fill the db you don‘t need to change it all the time. Now I‘m missing some keys like space, shift, minus, exclamation mark. Where i can find the right syntax?

                      cvp 1 Reply Last reply Reply Quote 0
                      • cvp
                        cvp @brumm last edited by

                        @brumm I'm sure that my script, not initially written for that, can be made easier...
                        I'll do it if you let me some time

                        1 Reply Last reply Reply Quote 0
                        • brumm
                          brumm last edited by

                          @cvp That is very kind of you, no hurry. I‘m not started coding. First I will design the Views and database structure.

                          cvp 2 Replies Last reply Reply Quote 0
                          • cvp
                            cvp @brumm last edited by

                            @brumm ouf 😅

                            1 Reply Last reply Reply Quote 1
                            • cvp
                              cvp @brumm last edited by cvp

                              @brumm Could you try this new (far from perfect) version and tell me if useful Double_keyboard.py

                              1 Reply Last reply Reply Quote 1
                              • brumm
                                brumm last edited by brumm

                                Wow! Thank you so much. Looks awesome.
                                @cvp Btw. would it be okay for you, if I upload my VocabularyTrainer with your code to Github? Or can I put a link to your gist in my future repository?

                                cvp 3 Replies Last reply Reply Quote 0
                                • cvp
                                  cvp @brumm last edited by

                                  @brumm My code is yours, do what you want. 😀

                                  1 Reply Last reply Reply Quote 1
                                  • cvp
                                    cvp @brumm last edited by

                                    @brumm Right alignment done in new version of Double_keyboard.py

                                    becomes

                                    1 Reply Last reply Reply Quote 2
                                    • cvp
                                      cvp @brumm last edited by

                                      @brumm my script defines as 2nd keyboard a Cyrillic one because my standard keyboard is Latin, but, of course, you could easily do the inverse...

                                      1 Reply Last reply Reply Quote 0
                                      • brumm
                                        brumm last edited by

                                        MyVocabTrainer

                                        Far away from being finished. Ugly code and only for fixed iPad 768x1024 resolution.

                                        1 Reply Last reply Reply Quote 1
                                        • First post
                                          Last post
                                        Powered by NodeBB Forums | Contributors