Giter Club home page Giter Club logo

Comments (3)

zenith391 avatar zenith391 commented on June 4, 2024 4

Yes, although I'm still planning the architecture of how will it be done, like should it be something similar to CSS (albeit with the bad and confusing parts due to backward-compatibility replaced), and how to apply it to native widgets consistently on all platforms. But it's coming soon:tm:.

from capy.

Losiel avatar Losiel commented on June 4, 2024

(Sorry for replying to an old issue) but what about something like DataWrapper but StyleWrapper?

const importantButton = capy.StyleWrapper(
  .{
     .backgroundColor = capy.rgb(255, 0, 0)
   }
)

and then for creating a button let's say

.button(.{.label = "DELETE YOUR ENTIRE OS"}).style(importantButton)

(maybe not limit buttons to only one style?. styles added first have less priority)
and if you do something like importantButton.backgroundColor.blue = 255 will update every component using the style. or even let styles use DataWrappers, but maybe that's too complex

This is just an idea I had and I don't know how cross platform would that be. However I think it's better than something like CSS because you don't have to parse and that would help linters (?)

from capy.

mgord9518 avatar mgord9518 commented on June 4, 2024

@zenith391 it should be possible to style a button using a bitmap for pretty much any conceivable UI kit, although it may have performance implications.

Maybe the theme engine could support basic drawing like lines, fill, alignment and gradients, then anything that somehow doesn't support drawing them on the fly could fall back on a pre-rendered bitmap? If this route is chosen, then a TinyVG (Zig-native vector image) Kvantum-like theme format could be used.

from capy.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.