Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Replace label on key #555

Closed
oz1cz opened this issue Apr 27, 2017 · 34 comments
Closed

Replace label on key #555

oz1cz opened this issue Apr 27, 2017 · 34 comments

Comments

@oz1cz
Copy link

oz1cz commented Apr 27, 2017

Is there any way to replace the label on a character key with an image?

I'm trying to create a classical Hebrew keyboard, and some of the vowel characters are so small that they are almost impossible to view in any reasonable font size. So for some of those characters, I would like to display a small image on the key button instead of the actual character.

Is this possible with the current code?

@Mottie
Copy link
Owner

Mottie commented Apr 27, 2017

Hi @oz1cz!

There are two ways to add an image to the key... (demo)

Add a background image to the specific key. In this example, the α (alpha) key is targeted using it's unique class name based on it's decimal ascii value (945, also known as 03B1 in hex):

/* target greek letter alpha */
.ui-keyboard-945 span {
  /* keyboard icon used in this example */
  background: url(css/images/keyboard.png) center center no-repeat;
  display: block;
  width: 30px;
  /* hide key text */
  text-indent: -999em;
}
/* needed for inline image (second method below) */
.ui-keyboard-button {
  vertical-align: middle;
}

And a second, bit more complex method - I really need to fix it - is to make an action key, then set the display value to be an image.

I just found out that including http:// in the image URL breaks the url inside the image, so I'll need to fix that in the next update.

// making an action key, it needs an action
$.keyboard.keyaction['β'] = 'β';

$('#keyboard2').keyboard({
  layout: 'custom',
  customLayout: {
    // wrap the key in curly brackets to make it
    // an action key
    'default': ['α {β}']
  },
  display: {
    // including a colon in the url breaks the image :(
  	'β': '<img src="css/images/keyboard.png">'
  }
});

@oz1cz
Copy link
Author

oz1cz commented Apr 28, 2017

Thank you, @Mottie, the CSS-based solution works very nicely for me!

(Using "text-indent: -999em" to hide the original key text was an eye-opener. :-) )

@Mottie Mottie mentioned this issue May 5, 2017
28 tasks
@andrewvharris
Copy link

Thanks for this. Unfortunately I am not knowledgeable enough to be able to make this work.

@Mottie
Copy link
Owner

Mottie commented Apr 17, 2018

Hi @andrewvharris!

Did you look at the demo from my first response? Adding an image in the display option doesn't work correctly at this time, but adding it as a background image in CSS will work. Where are you having issues? If the background image is too big, you may not see it, be sure to include a background-size: cover to shrink it down.

@andrewvharris
Copy link

andrewvharris commented Apr 17, 2018 via email

@Mottie
Copy link
Owner

Mottie commented Apr 17, 2018

Oh, well I think most musical symbols are included within unicode, so all you really would need is the unicode codepoint.

If you look in the demo I shared with you through email - copied to jsbin to show all the necessary code in the HTML panel - you'll see 'default': '\u{1d11e}:ABC_Music_Notation' added to the display setting. The \u{1d11e} portion is adding a "MUSICAL SYMBOL G CLEF" to the key using javascript unicode notation (\u{xxxx}); the "ABC_Music_Notation" portion becomes the tooltip (hover over the key to see it).

If you want to use an image, then I've updated the jsfiddle demo as follows (click the "ABC" button to switch layouts):

Script

// not really necessary, but changed to a space to not add any content
'default': ' :ABC_Music_Notation'

CSS

.ui-keyboard-default span {
  background-size: cover;
  display: inline-block;
  width: 20px;
  height: 20px;
  background-image: url("");
}

The following background image was reduced in size using https://tinypng.com/ and then converted into a data-uri using http://duri.me/.

clef

@andrewvharris
Copy link

andrewvharris commented Apr 18, 2018 via email

@Mottie
Copy link
Owner

Mottie commented Apr 18, 2018

In this example, we'll add an action key named {halfQuarter} (name it anything you want, but use the same name throughout the JavaScript and CSS).

  1. First we'll define the key action - this is the text you see after clicking the key.
  2. Then add it to the customLayout as {halfQuarter}.
  3. Set it's display to a space
  4. Define the background image in the css:
  • I clicked on the half quarter svg image on the wikipage and was taken to a page with only the svg showing.
  • Then go to https://dopiaza.org/tools/datauri/index.php, click on "Retrieve file from a URL" radio option.
  • Leave "Use base64 encoding" checked.
  • Click on "Generate Data URI".
  • Copy the data URI from the resulting input.
  • Paste the data URL inside the quotes of background-image: url('') in the CSS
$(function() {

	$.keyboard.keyaction.halfQuarter = 'z1';

  $('#keyboard').keyboard({
      layout: 'customLayout',
      customLayout: {
        'default': [
          '{halfQuarter}'
        ]
      },
      display: {
        'halfQuarter': ' '
      }
    })
    // activate the typing extension
    .addTyping({
      showTyping: true,
      delay: 250
    });

});

CSS

.ui-keyboard-halfQuarter span {
  width: 20px;
  height: 20px;
  display: inline-block;
  background-repeat: no-repeat;
  background-position: center center;
  background-image: url('');
}

@andrewvharris
Copy link

andrewvharris commented Apr 19, 2018 via email

@Mottie
Copy link
Owner

Mottie commented Apr 19, 2018

The code from each area of the example you linked (the CSS, HTML and Java) then all go in that html page inside the correct tags ?

Yes. But this is JavaScript. Java is a completely different language.

You don't really need to download all the files unless you plan to use it offline; but if you want, the whole package isn't that big. Download the zip file of the current build, extract and save the files to your hard drive somewhere. Then, make sure to point to the necessary files in the HTML. You'd need to repeat this process for any updates.

If you're planning on using the files online, then I would recommend pointing the js and css to cdnjs - it's a content delivery network so it will provide the needed files quickly. You'll need to manually change the links for any updates.

@Mottie
Copy link
Owner

Mottie commented Apr 19, 2018

I just made a change, not on the CDN yet, that will allow you to add an <img> inside the display option, so you won't need to add the images as a background:

display: {
  'halfQuarter': '<img src="https://upload.wikimedia.org/wikipedia/commons/0/03/QuarterRest.svg">'
}

You'll need to tweak the css a bit to get stuff to line up (demo). Also, I wouldn't recommend using that wikimedia url if you're planning on making the program work offline.

@Mottie
Copy link
Owner

Mottie commented Apr 19, 2018

Version 1.28.2 has been released with this change. It should be available on CDNJS soon.

@Mottie Mottie closed this as completed Apr 19, 2018
@Mottie Mottie removed the Version 2 label Apr 19, 2018
@andrewvharris
Copy link

It works brilliantly. Thank you so much

@andrewvharris
Copy link

andrewvharris commented Apr 20, 2018 via email

@Mottie
Copy link
Owner

Mottie commented Apr 20, 2018

Within in the keyboard initialization, add a change callback which calls the do_resize() function (demo):

change: function () {
  do_resize();
}

@andrewvharris
Copy link

andrewvharris commented Apr 20, 2018 via email

@andrewvharris
Copy link

andrewvharris commented Apr 23, 2018 via email

@Mottie
Copy link
Owner

Mottie commented Apr 23, 2018

Set the usePreview option to false.

@andrewvharris
Copy link

andrewvharris commented May 1, 2018 via email

@andrewvharris
Copy link

andrewvharris commented Jun 8, 2018 via email

@Mottie
Copy link
Owner

Mottie commented Jun 8, 2018

Very nice!

figure out now how to take the contents of the text area and compare it against a correct version

I think you should check out this code which checks and highlights the difference between two strings.

style the keyboard so that it, in fact, looks like a piano keyboard?

Yes, I have this demo on the wiki page that uses css absolute positioning to position the enter key, but in your case I think you could use the css from beautiful piano - here's a demo - but I'm not sure if you're going to include the black keys?

.ui-keyboard-button[class*="-A"],
.ui-keyboard-button[class*="-B"],
.ui-keyboard-button[class*="-C"],
.ui-keyboard-button[class*="-D"],
.ui-keyboard-button[class*="-E"],
.ui-keyboard-button[class*="-F"],
.ui-keyboard-button[class*="-G"] {
  background: linear-gradient(-30deg, #f5f5f5, #fff);
  box-shadow: inset 0 1px 0px #fff, inset 0 -1px 0px #fff,
    inset 1px 0px 0px #fff, inset -1px 0px 0px #fff,
    0 4px 3px rgba(0, 0, 0, 0.7);
  height: 100px;
  position: relative;
  margin: 2px 0 6px;
}

.ui-keyboard-button[class*="-A"]:active,
.ui-keyboard-button[class*="-B"]:active,
.ui-keyboard-button[class*="-C"]:active,
.ui-keyboard-button[class*="-D"]:active,
.ui-keyboard-button[class*="-E"]:active,
.ui-keyboard-button[class*="-F"]:active,
.ui-keyboard-button[class*="-G"]:active {
  -webkit-box-shadow: 0 2px 2px rgba(0, 0, 0, 0.4);
  -moz-box-shadow: 0 2px 2px rgba(0, 0, 0, 0.4);
  box-shadow: 0 2px 2px rgba(0, 0, 0, 0.4);
  position: relative;
  top: 2px;
}

.ui-keyboard-button[class*="-A"]:active:before,
.ui-keyboard-button[class*="-B"]:active:before,
.ui-keyboard-button[class*="-C"]:active:before,
.ui-keyboard-button[class*="-D"]:active:before,
.ui-keyboard-button[class*="-E"]:active:before,
.ui-keyboard-button[class*="-F"]:active:before,
.ui-keyboard-button[class*="-G"]:active:before {
  content: "";
  width: 0px;
  height: 0px;
  border-width: 216px 5px 0px;
  border-style: solid;
  border-color: transparent transparent transparent rgba(0, 0, 0, 0.1);
  position: absolute;
  left: 0px;
  top: 0px;
}

.ui-keyboard-button[class*="-A"]:active:after,
.ui-keyboard-button[class*="-B"]:active:after,
.ui-keyboard-button[class*="-C"]:active:after,
.ui-keyboard-button[class*="-D"]:active:after,
.ui-keyboard-button[class*="-E"]:active:after,
.ui-keyboard-button[class*="-F"]:active:after,
.ui-keyboard-button[class*="-G"]:active:after {
  content: "";
  width: 0px;
  height: 0px;
  border-width: 216px 5px 0px;
  border-style: solid;
  border-color: transparent rgba(0, 0, 0, 0.1) transparent transparent;
  position: absolute;
  right: 0px;
  top: 0px;
}

I also cleaned up the $.keyboard.keyaction key settings in that demo.

@Mottie
Copy link
Owner

Mottie commented Jun 8, 2018

Also, have you seen this pianoKeyboard library? It doesn't looks like it works with ABC notation, but it looks nice. 😸

@andrewvharris
Copy link

andrewvharris commented Jun 14, 2018 via email

@andrewvharris
Copy link

andrewvharris commented Jun 14, 2018 via email

@andrewvharris
Copy link

andrewvharris commented Jun 14, 2018 via email

@Mottie
Copy link
Owner

Mottie commented Jun 14, 2018

Oh? I was going to say yes, it is possible... but my OCD kicked in and I started working on it LOL

@andrewvharris
Copy link

andrewvharris commented Jun 14, 2018 via email

@Mottie
Copy link
Owner

Mottie commented Jun 14, 2018

What about something like this? demo

@Mottie
Copy link
Owner

Mottie commented Jun 14, 2018

Oops, I forgot to fix the shifted keyset to make flats... but I think you get the idea.

@andrewvharris
Copy link

andrewvharris commented Jun 14, 2018 via email

@Mottie
Copy link
Owner

Mottie commented Jun 14, 2018

LOL, and here's one with the black keys overlapping the white... demo.

@andrewvharris
Copy link

andrewvharris commented Jun 14, 2018 via email

@Mottie
Copy link
Owner

Mottie commented Jun 14, 2018

The demo is using the relative urls copied from the finaltest demo... I didn't bother changing them. It shouldn't alter the look on your web site.

@andrewvharris
Copy link

andrewvharris commented Jun 15, 2018 via email

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants