Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 533263
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 13, 20262026-05-13T09:29:28+00:00 2026-05-13T09:29:28+00:00

I’m working on an iPhone OS app whose primary view is a 2-D OpenGL

  • 0

I’m working on an iPhone OS app whose primary view is a 2-D OpenGL view (this is a subclass of Apple’s EAGLView class, basically setting up an ortho-projected 2D environment) that the user interacts with directly.

Sometimes (not at all times) I’d like to render some controls on top of this baseline GL view– think like a Heads-Up Display. Note that the baseline view underneath may be scrolling/animating while controls should appear to be fixed on the screen above.

I’m good with Cocoa views in general, and I’m pretty good with CoreGraphics, but I’m green with Open GL, and the EAGLView’s operations (and its relationship to CALayers) is fairly opaque to me. I’m not sure how to mix in other elements most effectively (read: best performance, least hassle, etc). I know that in a pinch, I can create and keep around geometry for all the other controls, and render those on top of my baseline geometry every time I paint/swap, and thus just keep everything the user sees on one single view. But I’m less certain about other techniques, such as having another view on top (UIKit/CG or GL?) or somehow creating other layers in my single view, etc.

If people would be so kind to write up some brief observations if they’ve travelled these roads before, or at least point me to documentation or existing discussion on this issue, I’d greatly appreciate it.

Thanks.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-13T09:29:28+00:00Added an answer on May 13, 2026 at 9:29 am

    Create your animated view as normal. Render it to a render target. What does this mean? Well, usually, when you ‘draw’ the polygons to the screen, you’re actually doing it to a normal surface (the primary surface), that just so happens to be the one that eventually goes to the screen. Instead of rendering to the screen surface, you can render to any old surface.

    Now, your HUD. Will this be exactly the same all the time or will it change? Will only bits of it change?

    If all of it changes, you’ll need to keep all the HUD geometry and textures in memory, and will have to render them onto your ‘scrolling’ surface as normal. You can them apply this final, composite render to the screen. I wouldn’t worry too much about hassle and performance here — the HUD can hardly be as complex as the background. You’ll have a few textures quads at most?

    If all of the hud is static, then you can render it to a separate surface when your app starts, then each frame render from that surface onto the animated surface you’re drawing each frame. This way you can unload all the HUD geom and textures right at the start. Of course, it might be the case that the surface takes up more memory — it depends on what resources your app needs most.

    If your had half changes and half not, then technically, you can pre-render the static parts and then render the other parts as you’re going along, but this is more hassle than the other two options.

    Your two main options depend on the dynamicness of the HUD. If it moves, you will need to redraw it onto your scene every frame. It sucks, but I can hardly imagine that geometry is complex compared to the rest of it. If it’s static, you can pre-render and just alpha blend one surface onto another before sending to the screen.

    As I said, it all depends on what resources your app will have spare.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

No related questions found

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.