有没有办法将 p5js 中的复选框外观设置为切换开关?

Posted

技术标签:

【中文标题】有没有办法将 p5js 中的复选框外观设置为切换开关?【英文标题】:Is there a way to style checkbox appearance in p5js to become a toggle switch? 【发布时间】:2022-01-11 10:30:06 【问题描述】:

我正在尝试使用 javascript 更改 p5 画布中复选框的外观,使其具有与 this 等切换开关相同的外观

我已经尝试在 this sketch 中的 css 文件中进行试验,但它似乎不起作用

任何帮助将不胜感激。谢谢

let checkbox;

function setup() 
  checkbox = createCheckbox("label", false);
  checkbox.changed(myCheckedEvent);

  createDiv(`
    <label class="switch">
      <input id="toggle" type="checkbox"  />
      <span class="slider round"></span>
    </label>`);

  checkbox = select('#toggle');


function myCheckedEvent() 
  if (this.checked()) 
    console.log("Checking!");
   else 
    console.log("Unchecking!");
  
html, body 
  margin: 0;
  padding: 0;

canvas 
  display: block;


/* The switch - the box around the slider */
.switch 
  position: relative;
  display: inline-block;
  width: 60px;
  height: 34px;


/* Hide default HTML checkbox */
.siwtch input 
  opacity: 0;
  width: 0;
  height: 0;


/* The slider */
.slider 
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  -webkit-transition: .4s;
  transition: .4s;


.slider:before 
  position: absolute;
  content: "";
  height: 26px;
  width: 26px;
  left: 4px;
  bottom: 4px;
  background-color: white;
  -webkit-transition: .4s;
  transition: .4s;


#toggle:checked + .slider 
  background-color: #2196F3;


#toggle:focus + .slider 
  box-shadow: 0 0 1px #2196F3;


#toggle:checked + .slider:before 
  -webkit-transform: translateX(26px);
  -ms-transform: translateX(26px);
  transform: translateX(26px);


/* Rounded sliders */
.slider.round 
  border-radius: 34px;


.slider.round:before 
  border-radius: 50%;
&lt;script src="https://cdnjs.cloudflare.com/ajax/libs/p5.js/1.4.0/p5.js"&gt;&lt;/script&gt;

【问题讨论】:

请将您的代码放入您的问题中并描述什么不起作用。当我运行你的代码时,它显示了一个切换的开关。 【参考方案1】:

你的方法基本上看起来很合理,它只需要一些调整(见 cmets):

let checkbox;

function setup() 
  noCanvas();
  // There's no need to use createCheckbox() since you're create the <input /> tag yourself
  // Also I got rid of the wrapping div since it wasn't strictly necessary.
  let label = createElement(
    'label',
    `<input id="toggle" type="checkbox" />
     <span class="slider round"></span>`
  );
  
  // Because I'm using createElement() to create the label I have to add the class attribute:
  label.addClass('switch');

  checkbox = select('#toggle');
  // Register the event handler after using select() to get the p5.Element for the checkbox.
  checkbox.changed(myCheckedEvent);


function myCheckedEvent() 
  if (this.checked()) 
    console.log("Checking!");
   else 
    console.log("Unchecking!");
  
html, body 
  margin: 0;
  padding: 0;


/* The switch - the box around the slider */
.switch 
  position: relative;
  display: inline-block;
  width: 60px;
  height: 34px;


/* Hide default HTML checkbox */
/* COMMENT: there was a typo here, uses to be .siwtch */
.switch input 
  opacity: 0;
  width: 0;
  height: 0;


/* The slider */
.slider 
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  -webkit-transition: .4s;
  transition: .4s;


.slider:before 
  position: absolute;
  content: "";
  height: 26px;
  width: 26px;
  left: 4px;
  bottom: 4px;
  background-color: white;
  -webkit-transition: .4s;
  transition: .4s;


#toggle:checked + .slider 
  background-color: #2196F3;


#toggle:focus + .slider 
  box-shadow: 0 0 1px #2196F3;


#toggle:checked + .slider:before 
  -webkit-transform: translateX(26px);
  -ms-transform: translateX(26px);
  transform: translateX(26px);


/* Rounded sliders */
.slider.round 
  border-radius: 34px;


.slider.round:before 
  border-radius: 50%;
&lt;script src="https://cdnjs.cloudflare.com/ajax/libs/p5.js/1.4.0/p5.js"&gt;&lt;/script&gt;

【讨论】:

我已经实现了你的建议,它在 p5.js 中运行良好,但是当我使用 Atom 在我的项目中运行它时,为什么它似乎不起作用? 不看整个项目就无法说出口。我猜很可能是一些冲突的 CSS 影响了这个标签/输入/跨度的显示方式。我建议使用 Web 浏览器的开发人员工具来查看元素并查看计算的 CSS 属性。那里可能存在一些差异,然后您可以将冲突设置追溯到我们项目中的源。

以上是关于有没有办法将 p5js 中的复选框外观设置为切换开关?的主要内容,如果未能解决你的问题,请参考以下文章

有没有办法在引导 Div 元素中调整 p5js 画布的大小?

CSS:将复选框设置为看起来像按钮,是不是有悬停?

有没有办法将“a”标签链接取消设置为默认颜色

使用 CSS 更改 Asp:CheckBox 的样式/外观

Bootstrap Toggle:将多个复选框的切换状态设置为“关闭”

html 切换(开/关)复选框