Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/xiaobin83/Unity3D.EmojiText
EmojiText in Unity3D
https://github.com/xiaobin83/Unity3D.EmojiText
emoji ui unity3d
Last synced: 3 months ago
JSON representation
EmojiText in Unity3D
- Host: GitHub
- URL: https://github.com/xiaobin83/Unity3D.EmojiText
- Owner: xiaobin83
- License: mit
- Created: 2017-04-22T13:25:00.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2018-01-13T21:46:57.000Z (about 7 years ago)
- Last Synced: 2024-08-03T19:09:47.505Z (7 months ago)
- Topics: emoji, ui, unity3d
- Language: C#
- Size: 5.67 MB
- Stars: 39
- Watchers: 5
- Forks: 11
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-unity-open-source-on-github - Unity3D.EmojiText - EmojiText in Unity3D (Text)
README
Untiy3D.EmojiText
data:image/s3,"s3://crabby-images/513c8/513c88be754964e97cc17b166eeae6bec7affc2e" alt="EmojiText"
## EmojiText
+ Extends from UnityEngine.UI.Text
+ Has the same performance if no EmojiConfig attached.
+ Layout handled by UnityEngine.UI.Text, only replaces UVs of generated text mesh. Thus you can use RichText to change size and color of text. (Emoji sprite wont change color. I disabled it. And you also need to set sizeFactor in EmojiConfig to 1)
+ No sub GameObject needed (actually need one for attaching CanvasRenderer). Use CanvasRenderer to render emoji mesh.
+ Support hyperlink click event with markdown link syntax. `[ClickMe](link_to_some_place)`
+ Support pre-defined text by markdown predefined text syntax. \`predefined text\`. And predefined text replacements delegates to `EmojiText.willInsertBackOnePredefinedString`.
+ Support escape character by input \uxxxxx directly.
+ Generate your own EmojiConfig with different emojis by using AltasBaker in Emoji -> Atlas Baker (you can use altas baker for other stuff, it reports all UVs and names to AtlasBakerWizard.OnAtlasBaked)
+ Works in edit mode.## Quick setup
1. Copy Unity3D.EmojiText to your own Assets folder
2. Create GameObject under Canvas
3. Attach EmojiText component to the GameObject just created
4. Drag and drop asset `Unity3D.EmojiText/EmojiConfig` to Config fielddata:image/s3,"s3://crabby-images/e2548/e25484301e79141b62a5698eaaca8e9f8752763d" alt="EmojiConfig"
5. Now you have emoji text with all TwitterEmoji characters.
6. If you want to handle hyperlink (markdown syntax), just add some Href On Clicked Event
7. Check `scn_demo` for more details.
8. Unity3D 5.3.x has bugs in InputField with emoji charaters, plz check `EmojiTouchScreenInputField.cs` for details (i just copy from UnityEngine.UI and did some fix).## Create your own emoji characters
1. Create folder in your project. (like `Assets/MyEmoji`)
2. Copy your emoji sprites to this folder. The name of sprite should be the unicode of character. If you want to replace `A` with emoji sprite, just put a `41.png` to MyEmoji folderdata:image/s3,"s3://crabby-images/98c22/98c22fa8b3a0a3f98f9e57ae1a1bf4f6d6cb262d" alt="EmojiConfig_02_a"
3. Add EmojiText component to a GameObject without assigning EmojiConfig, you can see `Create Config` button in Inspector
data:image/s3,"s3://crabby-images/d441f/d441f7d84752094f339fd460930fe5f899b386db" alt="EmojiConfig_02_b"
4. Press `Create Config` button, you will get a EmojiConfig.asset in Assets folder
data:image/s3,"s3://crabby-images/3f5a3/3f5a31f536feef0202c74bbe8c02252dbd2064c4" alt="EmojiConfig_02_c"
5. Select EmojiConfig.asset. You can see
data:image/s3,"s3://crabby-images/c31c5/c31c5340275f4ed16b23d0d28552a0e1d80dc170" alt="EmojiConfig_02_d"
6. Click `Create Atlas` and in the Atlas tool box, put path to `Asset/MyEmoji` in path to texture field, and then press `Atlas` button
data:image/s3,"s3://crabby-images/7644c/7644c42736f25be84222841f2918e78253ba6cd7" alt="EmojiConfig_02"
7. Now you will atlas texture and correct emoji config with character `A`
data:image/s3,"s3://crabby-images/f1ec6/f1ec61c644bb18259e78ad5342ac8bd1d382453c" alt="EmojiConfig_03"
data:image/s3,"s3://crabby-images/3b216/3b21656b3ac7431be917d52c0b1f8601320ed2b9" alt="EmojiConfig_04"
data:image/s3,"s3://crabby-images/bea25/bea257bbac2f744fe8f179ea710913c998d67dff" alt="EmojiConfig_05"8. If you want to add more emoji character to exist config, you can add multiple paths in atlas step
data:image/s3,"s3://crabby-images/8075d/8075d688414d5b08132ab96af31f198d3ed247b8" alt="EmojiConfig_06"
## License
TwitterEmoji comes from [Twemoji project](https://github.com/twitter/twemoji). It licensed under [CC-BY 4.0](https://creativecommons.org/licenses/by/4.0/). And I copied from [Unity-UI-emoji](https://github.com/mcraiha/Unity-UI-emoji).
Idea and some part of code come from [Unity-UI-emoji](https://github.com/mcraiha/Unity-UI-emoji), I changed it to fit my implementation.
## Misc
steam: 0x600d1dea