小编Mik*_*ans的帖子

如何在给定切线方向的二次贝塞尔曲线上找到一个点(如果有)?

我目前正在使用 python 库从 TrueType 字体中提取笔划 - 在这里,我将笔划定义为在测试点与其反射点之间运行的中线。我使用术语“反射点”来指代“墨水”区域另一侧的最近点,在正常情况下(除了在衬线词干处),该点的切线方向也与测试点相反.

我正在使用 fontTools 和从http://pomax.github.io/bezierinfo/#extremities 中描述的处理代码推出的贝塞尔库在 python 中工作。

目前我被困在如何找到具有给定切线的二次贝塞尔曲线上的点,我的数学技能在美好的一天非常基本,头脑清晰[现在不是仪式]所以我希望头脑更敏锐的人可以指出如何实现这一目标的鸟瞰概述。

目前,我唯一能想到的就是用类似于 Newton-Raphson 求根算法的方法在数值上接近它,但根据目标方向值评估一阶导数。然而,我希望有一个象征性的解决方案,因为这需要在字形轮廓中的每条曲线的每条其他曲线上运行。

python math bezier

3
推荐指数
1
解决办法
975
查看次数

如何选择一个Reactjs组件模板中使用的所有子组件(不是DOM元素)?

我遇到的情况是,我将两个要素捆绑在一起,而一个董事会以不可商议的方式始终由4个细分小组组成:

var BoardPanel = React.createClass({
  getInitialState: function() {
    return { someval: '' };
  }, 
  render: function() {
    <div>{this.state.someval}</div>
  },
  doSomething: function(v) {
    setState({ someval: v });
  }
});

var BoardLayout = React.createClass({
  render: function() {
    <div>
      <h1>{this.props.label{</h1>
      <div ref="panels">
        <BoardPanel />
        <BoardPanel />
        <BoardPanel />
        <BoardPanel />
      </div>
    </div>
  }
});
Run Code Online (Sandbox Code Playgroud)

BoardLayout应该能够统一地告诉每个BoardPanel调用面板API函数,所以我想做React.js的等效项:

this.querySelectorAll("BoardPanel")
    .array()
    .forEach(function(panel, idx) {
       panel.doSomething(idx);
    });
Run Code Online (Sandbox Code Playgroud)

请注意,我明确希望在这里访问DOM节点,我要访问的阵营定义的虚拟元素,对通话功能,并且永远不会触及任何真正的浏览器的DOM使用。

我看了看React.children实用程序函数,但是这些函数没什么用,因为无法指定我想要的子代,并且this.props.children要给我两个div元素,因为BoardPanel元素位于模板内部。

(我也很反对ref="..."为每个BoardPanel 添加一次性标识符,因为考虑到格式合理,结构化的标记,不需要做任何事情,这是一个可行的解决方法,但似乎像拍打一样明智。 HTML文件中每个元素的ID,而不是依赖查询选择器)

我可以通过根本不将它们实际包含在模板中并使用React.create(BoardPanel)in 添加它们来动态生成它们,BoardLayout.getInitialState但这会使立即具有洞察力的模板结构变成不透明的占位符,这也是我不希望做的事情。 …

reactjs react-jsx

3
推荐指数
1
解决办法
8127
查看次数

将 Promise.all 保存到两个变量中

我有这段代码,我想将 Promise.all 的结果保存到两个变量中。问题是当 (this.data = data) 时我变得不确定

    const {data,recents} : any = await Promise.all([
      this.$store.dispatch('algo', input),
      this.$store.dispatch('algo', input)
    ])
    this.data = data
    this.recents = recents
Run Code Online (Sandbox Code Playgroud)

javascript

3
推荐指数
1
解决办法
1450
查看次数

如何在Android中填充贝塞尔曲线下的区域

我正在寻找一种在 Android 中的三次贝塞尔曲线下填充区域的方法。具体来说,我试图在自定义视图中绘制如下图所示的图形。我的想法是画一个圆和两条镜像的三次贝塞尔曲线并填充它们下方的区域。是否有内置的 Android 方式来存档此文件,还是我必须找到其他解决方案?如果是这样,您能帮我找到替代解决方案吗?

我想画的形状:

我想画的形状

android bezier fill android-view

2
推荐指数
1
解决办法
1068
查看次数

无法将选项卡和空格插入PDBox PDF文档

我想在PDFBOX创建的pdf中打印它.它不会让我插入标签和空格,因为字体不支持它们.为什么这是一个问题,更重要的是,我该如何解决?

StudentData student = listOfDebtors.get(j);

contentStream.beginText();
contentStream.setFont(font, 8);
contentStream.newLineAtOffset(xPosition, yPosition);
contentStream.showText("Member #:"+ student.getMembershipNumber() + "\t"
            + "Grade:" + getStudentGradeInSchool(student.getYearGraduate()) + "\t"
            + "Year Joined" + student.getYearJoined() + "\n" 
            + "Name:" + student.getFirstName() + " " + student.getLastName() + "\n"
            + "Amount Owed : $" + student.getAmountOwed()); 
Run Code Online (Sandbox Code Playgroud)

显示错误:

Caused by: java.lang.IllegalArgumentException: No glyph for U+0009 in font Courier
    at org.apache.pdfbox.pdmodel.font.PDType1Font.encode(PDType1Font.java:353)
    at org.apache.pdfbox.pdmodel.font.PDFont.encode(PDFont.java:283)
    at org.apache.pdfbox.pdmodel.PDPageContentStream.showText(PDPageContentStream.java:341)
    at fbla.rahulshah.database.dataManipulation.PDFCreator.createDebtorPDF(PDFCreator.java:61)
    at fbla.rahulshah.database.view.MainScreenController.generateDebtReport(MainScreenController.java:114)
    ... 62 more
Run Code Online (Sandbox Code Playgroud)

java pdf fonts javafx pdfbox

2
推荐指数
2
解决办法
3625
查看次数

有没有办法使用 JavaScript 从 tiff 图像中提取地理标签?

我正在开展一个项目,需要使用正射马赛克地图。该地图采用 .tiff 格式。我想从该地图中提取地理信息,以便我可以将其正确覆盖在谷歌地图上。我在这个项目中使用平均堆栈。

所以我的最后一个问题是:有没有办法使用 JavaScript 从 tiff 图像中提取地理标签?

编辑:当我使用 Maptiler(https://www.maptiler.com/)时,它会自动将 .tif 文件正确放置在谷歌地图上。我想知道它如何提取信息并将其放置在地图上,以便我可以自己完成。

javascript tiff maptiler

2
推荐指数
1
解决办法
1374
查看次数

使用具有动态选择而不是硬编码列表的 Wagtail“ChoiceBlock”

我们有一个博客模型的设置,该模型与 BlogPageCategory 有很多关系,并且我们有一个“最近的博客文章”流字段块,可让您指定是显示 X 篇最新博客文章的卡片,还是来自特定类别的 X 篇最新博客文章.

因此,我们从以下代码开始:

from wagtail.core import blocks


class RecentBlogEntries(blocks.StructBlock):
    title = blocks.CharBlock(
        required=True,
    )

    category_filter = blocks.ChoiceBlock(
        label='Filter by Category',
        required=False,
        choices=[
            ('all', 'All'),
            ('First Category', 'First Category'),
            ('...',. '...'),
        ],
    )

    ...
Run Code Online (Sandbox Code Playgroud)

但是对类别进行硬编码有点傻,能够从“列表是什么,现在,基于 BlogPageCategory 的 CMS 数据”中选择它们会方便得多。但是,以下代码(当然)变成了同样硬编码的迁移:

from wagtail.core import blocks
from ... import BlogPageCategory


class RecentBlogEntries(blocks.StructBlock):
    title = blocks.CharBlock(
        required=True,
    )

    choices = [ (cat.name, cat.name) for cat in BlogPageCategory.objects.all()]
    choices.sort()
    choices.insert(0, ('all', 'All'))

    category_filter = blocks.ChoiceBlock(
        label='Filter by Category',
        required=False,
        choices=choices,
    ) …
Run Code Online (Sandbox Code Playgroud)

django wagtail

2
推荐指数
1
解决办法
700
查看次数

按正则表达式拆分与多个单字符拆分性能

我使用此基准比较了通过正则表达式和多个单字符拆分来拆分字符串

import org.openjdk.jmh.annotations.*;

import java.io.IOException;
import java.util.concurrent.TimeUnit;

public class Test {
    static String start = "1, 2, 3, 4, 5, 6, 7, 8. 9. 10. 11. 12.1, 2, 3, 4, 5, 6, 7, 8. 9. 10. 11. 12.1, 2, 3, 4, 5, 6, 7, 8. 9. 10. 11. 12.1, 2, 3, 4, 5, 6, 7, 8. 9. 10. 11. 12.1, 2, 3, 4, 5, 6, 7, 8. 9. 10. 11. 12.1, 2, 3, 4, 5, 6, 7, 8. 9. 10. …
Run Code Online (Sandbox Code Playgroud)

java performance split jmh

2
推荐指数
1
解决办法
76
查看次数

我可以在 React 中将 tailwind className 作为 props 传递吗?

我制作了一个 MessageBanner 组件,并想从中制作多个横幅,例如 MessageSuccess(绿色主题)和 MessageError(红色主题)。我尝试传递背景颜色、文本颜色和边框颜色的类名,但没有成功。请帮忙。

这是 MessageBanner.tsx。

export const MessageBanner: VFC<Props> = memo(props => {
  const { title, description, bgColor, textColor, borderColor } = props
  return (
    <>
      <div
        className={`${bgColor} ${textColor} ${borderColor} pointer-events-autoborder-t-4 rounded-b  px-4 py-3 shadow-md duration-1000`}
        role='alert'
      >
        <div className='flex'>
          <div>
            <p className='font-bold'>{title}</p>
            <p className='text-sm'>{description}</p>
          </div>
        </div>
      </div>
    </>
  )
})
Run Code Online (Sandbox Code Playgroud)

这是 MessageSuccess 组件。我尝试不使用“.”,例如使用“bg-green-100”而不是“.bg-green-100”,但都没有成功。

export const MessageSuccess: VFC = () => {
  return (
    <MessageBanner
      title='Welcome Back'
      description='You have successfully logged in'
      bgColor='.bg-green-100'
      textColor='.green-900'
      borderColor='.border-green-500'
    />
  )
} …
Run Code Online (Sandbox Code Playgroud)

typescript reactjs tailwind-css

2
推荐指数
1
解决办法
1万
查看次数

多项式系数的最大递归

最近,我在 YouTube 上发现了3Blue1Brown-OlympiadLevelCounting提出的一个有趣的计数问题。问题是找到集合 {1, 2, ..., 2000} 中元素之和能被 5 整除的子集的数量。格兰特·桑德森(Grant Sanderson)提出了一个漂亮的解决方案,但他也讨论了如果在计算机上实现该算法来有效解决问题,该算法可能会变得多么麻烦。

然而,由于欧拉的工作,使用整数分区来解决这个问题是有好处的。解决方案是小于或等于 2000 的所有 5 倍数的不同分区的总和,类似于我几年前在 MathstackExchange 上发布的内容,其中使用“dxiv”的注释是此代码的关键。

毫无疑问,格兰特·桑德森的解决方案是优雅的,因为它不需要计算机,不需要冗长的计算就可以找到。

我的代码是:

import numpy as np

def p(k):
    if k == 1:
        return np.array([1, 1])
    else:
        q = p(k - 1)
    return add(q, np.append(np.zeros(k, int), q))


def add(u, v):
    u = np.append(u, np.zeros(len(v) - len(u), int))
    return np.add(u, v)


def test(n):
    a = 1 << n
    b = 1 << (n//5)
    b *= 4
    return (a+b)//5


n …
Run Code Online (Sandbox Code Playgroud)

python algorithm math numpy python-3.x

2
推荐指数
1
解决办法
99
查看次数