Terminal Scroll Area
data:image/s3,"s3://crabby-images/3676c/3676c006f4499b86d24578a0480fcaab4a6a2009" alt="Gem Version"
This gem lets the user display large text on terminal by creating a scroll area in which only a specified portion of the text is displayed at a time. This portion can be moved to reveal other parts of the text, analogous to a GUI scroll area, or a more general purpose pager. This gem is useful when your program needs to display a large amount of text that may not fit into the screen.
The ScrollArea
class, which is not interactive, does not use Curses or a similar screen management library. The InteractiveScrollArea
class does not rely on the Curses library and instead uses the TTY toolkit, which has cross platform support and support for many types of terminals/terminal emulators. Therefore this gem should also have the same level of support.
Installation
gem install 'terminal-scroll-area'
or add it to your project's Gemfile
:
gem 'terminal-scroll-area'
Usage
ScrollArea
class
- Simple scroll area which lets you programmatically scroll the content in all directions.
- Initialise:
width = 5
height = 5
scroll = ScrollArea.new(width, height)
- Set the content that the scroll area will contain:
scroll.content = "some text"
scroll.add_string("some string")
scroll.add_line("some line")
- Render scroll area to get the portion of the entire content which is in view:
print(scroll.render)
- Scroll in all directions to reveal other portions:
scroll.scroll_up
- Scroll area lets you access some values you may find useful:
scroll.start_x
scroll.start_y
scroll.end_x
scroll.end_y
InteractiveScrollArea
- Regular
ScrollArea
lets you scroll the content with scroll_<direction>
methods. InteractiveScrollArea
displays an interactive scroll area where the user can use arrow keys to control scrolling of the content (e.g. up arrow scrolls up, etc.). - This class will automatically print a new rendering of the area after user has triggered a scroll event by pressing a key. The previously printed rendering is removed and the updated rendering is printed in the same area, thereby giving the feeling of interactivity.
width = 5
height = 5
interactive = InteractiveScrollArea(width, height)
interactive.content = "some text"
interactive.scroll